/* 基础样式重置 */
* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}
:root {
	--bg-color: #F8F3EA;
	--text-dark: #3E4048;
	--text-gray: #7B7B7B;
	--text-light-gray: #8D8D8D;
	--button-bg: #D6CFBE;
	--button-light: #D4D0C1;
	--white: #FFFFFF;
	--black: #000000;
	--accent-red: #A22324;
}
body {
	font-family: 'Noto Serif JP', serif;
	background-color: var(--bg-color);
	color: var(--text-dark);
	line-height: 1.6;
	overflow-x: hidden;
}
.tour-detail-notes-section p span{
	text-wrap-mode: wrap !important;
}
.tour-detail-include-section p span{
	text-wrap-mode: wrap !important;
}
.container {
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 20px;
}
/* Header 样式 */
.header {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 141px;
	padding: 25px 0;
	background: transparent;
	z-index: 1001;
	transition: background 0.3s ease;
}
.header.scrolled {
	position: fixed;
	height: 91px;
	padding: 0;
	background: rgba(51, 51, 51, 0.95);
}
.header-container {
	max-width: 1440px;
	margin: 0 auto;
	display: flex;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	justify-content: space-between;
	height: 100%;
	padding: 0 40px;
	position: relative;
	gap: 40px;
}
.wap{
	display: none;
}
.travel{
    position: relative;
}
.header-left {
	display: flex;
	align-items: center;
}
.header-right {
	display: flex;
	align-items: center;
	gap: 15px;
}
.menu-toggle {
	display: block;
	cursor: pointer;
	z-index: 1001;
	width: 30px;
	height: 9px;
}

@media (min-width: 769px) {
	.menu-toggle {
		visibility: visible;
	}
}

.nav-menu {
	display: flex;
	align-items: center;
	gap: 30px;
	justify-content: center;
	flex-wrap: wrap;
}

.nav-link {
	color: var(--white);
	text-decoration: none;
	font-weight: 600;
	font-size: 14.5px;
	letter-spacing: 0.05em;
	line-height: 2em;
	transition: opacity 0.3s ease;
	white-space: nowrap;
}

.nav-link:hover {
	opacity: 0.7;
}

.nav-link.active {
	opacity: 1;
	position: relative;
}

.nav-link.active::after {
	content: '';
	position: absolute;
	bottom: -5px;
	left: 0;
	right: 0;
	height: 2px;
	background-color: var(--white);
}

.nav-dropdown {
	display: flex;
	gap: 20px;
}
.languages{
	position: relative;
}
.language-switch {
	display: flex;
	align-items: center;
	gap: 7px;
	cursor: pointer;
}
.language-switch.on img{
	transform: rotate(180deg);
}
.languages1{
	display: none;
	position: absolute;
	left: 0;
	top: 100%;
}
.languages1 a{
	display: block;
	min-width: 172px;
	line-height: 40px;
	background-color: #EDE5D8;
	padding: 0 10px;
	font-weight: 600;
	font-size: 14px;
	letter-spacing: 0.72px;
	color: #3E4048;
	text-decoration: none;
}
.languages1 a:hover{
	background-color: #D4D0C1;
}
.user-icon {
	cursor: pointer;
	transition: opacity 0.3s ease;
	display: flex;
	align-items: center;
	justify-content: center;
}
.user-icon a{
	margin-left: 30px;
}
.user-icon a img{
	width: 30px;
}
.user-icon:hover {
	opacity: 0.7;
}
.headTc{
	display: none;
	position: fixed;
	right: 0;
	top: 0;
	z-index: 1003;
	width: 380px;
	height: 100%;
	overflow-y: scroll;
	padding: 30px;
	background-color: #E0DACF;
}
.headTc::-webkit-scrollbar {
	width: 0;
}
.headTc::-webkit-scrollbar-thumb {
	border-radius: 10px;
	box-shadow: inset 0 0 11px rgba(216,216,216,0.11);
	background: rgba(216,216,216,0.11);
}
.headTc::-webkit-scrollbar-track {
	box-shadow: inset 0 0 11px rgba(216,216,216,0.11);
	border-radius: 10px;
	background: rgba(216,216,216,0.02);
}
.headTc1{
	font-size: 0;
	text-align: right;
}
.headTc1 a{
	display: inline-block;
	vertical-align: middle;
	margin-left: 30px;
}
.headTc1 a img{
    width: 32px;
}
.headTc2{
	margin-top: 30px;
}
.headTc2 a{
	display: block;
	font-weight: 600;
	font-size: 12px;
	line-height: 21px;
	letter-spacing: 0.72px;
	color: #3E4048;
	text-decoration: none;
	transition: all .5s;
}
.headTc2 a:first-child{
	margin-top: 0;
}
.headTc2 a:hover{
    transform: translateY(-5px);
    opacity: 0.5;
}
.headTc3{
	/* margin-top: 10px; */
	margin-bottom: 20px;
	position: relative;
}
.headTc4{
	display: inline-flex;
	align-items: center;
	cursor: pointer;
}
.headTc4 span{
	font-weight: 600;
	font-size: 12px;
	line-height: 21px;
	letter-spacing: 0.72px;
	color: #3E4048;
	margin-right: 6px;
}
.headTc5{
	margin-top: 20px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
}
.headTc5 a{
	margin-top: 10px;
	width: calc((100% - 14px)/2);
	display: flex;
	align-items: center;
	justify-content: space-between;
	background-color: #FFFFFF;
	padding: 0 8px;
	height: 32px;
	border-radius: 16px;
	font-weight: 600;
	font-size: 12px;
	letter-spacing: 0.72px;
	color: #3E4048;
	text-decoration: none;
	transition: all .5s;
}
.headTc5 a img{
	width: 18px;
}
.headTc5 a:hover{
    transform: translateY(-5px);
    opacity: 0.5;
}
.headTc6{
	margin-top: 30px;
}
.headTc6 a{
	font-weight: 600;
	font-size: 12px;
	line-height: 21px;
	letter-spacing: 0.72px;
	text-decoration: underline;
	color: #3E4048;
}
.headTc7{
	margin-top: 10px;
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
}
.headTc8{
	flex: 1;
}
.headTc8a{
	font-weight: 600;
	font-size: 12px;
	line-height: 21px;
	letter-spacing: 0.72px;
	color: #3E4048;
}
.headTc8b{
	font-weight: 500;
	font-size: 12px;
	line-height: 21px;
	/*line-height: 29px;*/
	letter-spacing: 0.72px;
	color: #3E4048;
}
.headTc9{
	margin-left: 20px;
	width: 150px;
	display: flex;
	justify-content: flex-end;
	
}
.headTc10{
	font-size: 0;
}
.headTc11{
	display: none;
	margin-top: 10px;
	font-weight: 500;
	font-size: 11.76px;
	line-height: 27.44px;
	letter-spacing: 0.36px;
	text-align: center;
	color: #2A2C2C;
}
.headTc12{
	margin-top: 10px;
	font-size: 0;
	text-align: left;
}
.headTc12 a{
	display: inline-block;
	vertical-align: middle;
	margin: 0 3px;
	font-size: 0;
	width: 25px;
	transition: all .5s ease;
}
.headTc12 a:hover{
    transform: translateY(-5px);
    opacity: .5;
}

/* Hero Section 样式 */
.hero {
	position: relative;
	/* width: 100%; */
	margin: 25px 25px 0;
	height: 501px;
	/* min-height: 787px; */
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
}

.hero-background {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border-radius: 30px;
	overflow: hidden;
	/* margin: 25px; */
}
.hero-background .swiper-slide img{
	width:100%;
	height:auto;
	min-height:100%;
	transition:1s linear 2s;
	transform:scale(1.1,1.1);
}
.hero-background .swiper-slide-active img,.swiper-slide-duplicate-active img{
	transition:6s linear;
	transform:scale(1,1);
}

.hero-content {
	position: relative;
	z-index: 2;
	width: 100%;
	height: 100%;
	max-width: 1440px;
	margin: 0 auto;
	color: var(--white);
	padding: 0;
}

/* Logo 完全居中在轮播图中 */
.hero-logo {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	text-align: center;
	animation: fadeInUp1 1s ease;
}

.logo-img {
	/* width: 165px; */
	height: auto;
	display: block;
	margin: 0 auto;
}

.logo-text {
	display: none;
	font-family: 'Zen Old Mincho', serif;
	font-weight: 500;
	font-size: 24px;
	line-height: 2.33em;
	letter-spacing: 0.03em;
	margin: 10px 0 0 0;
	color: var(--white);
}
.logo a{
    display: flex;
    align-items: center;
    font-weight: 500;
    font-size: 0;
    line-height: 56px;
    letter-spacing: 0.72px;
    color: #FFFFFF;
    text-decoration: none;
}
.logo a img{
    width: 157px;
}

/* 标题文字在左下 */
.hero-text-left {
	position: absolute;
	bottom: 120px;
	left: 105px;
	text-align: left;
	max-width: 400px;
}

.hero-title {
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
	font-size: 35px;
	line-height: 1.6em;
	letter-spacing: 0.02em;
	margin: 0 0 15px 0;
	text-align: left;
	animation: fadeInUp 1s ease 0.2s both;
}

.hero-description {
	font-weight: 500;
	font-size: 14.5px;
	line-height: 2em;
	letter-spacing: 0.05em;
	margin: 0;
	text-align: left;
	animation: fadeInUp 1s ease 0.4s both;
}

/* 底部区域：滚动指示和按钮 */
.hero-bottom {
	position: absolute;
	bottom: 40px;
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 15px;
}

.hero-scroll {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	animation: fadeInUp 1s ease 0.8s both, bounce 2s ease-in-out infinite;
}

.scroll-text {
	font-family: 'Crimson Pro', serif;
	font-weight: 500;
	font-size: 14.5px;
	letter-spacing: 0.05em;
}

.scroll-arrow {
	animation: bounce-arrow 2s ease-in-out infinite;
}
.dbbutt{
	position: fixed;
	left: 50%;
	bottom: 30px;
	z-index: 1002;
	transform: translateX(-50%);
}
.hero-cta {
	display: inline-block;
	padding: 12px 32px;
	background-color: var(--button-bg);
	border-radius: 111.375px;
	text-decoration: none;
	color: var(--text-dark);
	font-family: 'Zen Old Mincho', serif;
	font-weight: 600;
	font-size: 18px;
	letter-spacing: 0.04em;
	transition: transform 0.3s ease, box-shadow 0.3s ease;
	animation: fadeInUp 1s ease 1s both;
	white-space: nowrap;
	box-sizing: border-box;
}

.hero-cta:hover {
	transform: translateX(5px) scale(1.05) !important;
	box-shadow: 0 5px 15px rgba(0, 0, 0, 0.2);
}

/* News Section 样式 - 根据图片优化 */
.news-section {
	padding: 96px 0 0;
	background-color: var(--bg-color);
}

.news-section .container {
	display: flex;
	gap: 137px;
	align-items: flex-start;
	max-width: 1440px;
	padding: 0 72px;
}

.news-header {
	flex-shrink: 0;
	width: 324px;
}

.section-title {
	font-weight: 500;
	font-size: 42px;
	line-height: 1.6em;
	letter-spacing: 0.017em;
	color: var(--text-dark);
	margin-bottom: 0;
}

.section-subtitle {
	font-weight: 500;
	font-size: 22px;
	line-height: 1em;
	letter-spacing: 0.033em;
	color: var(--text-dark);
}

.news-list-wrapper {
	flex: 1;
}

.news-list {
	margin-bottom: 0;
}

.news-item {
	/* display: flex;
	align-items: flex-start; */
	display: block;
	padding: 10px 0;
	border-bottom: 1px solid #8D8D8D;
	text-decoration: none;
	transition: background-color 0.3s ease;
	/* gap: 0; */
}

.news-item:hover {
	background-color: rgba(0, 0, 0, 0.02);
}


.news-date {
	flex-shrink: 0;
	font-weight: 600;
	font-size: 14.5px;
	line-height: 2em;
	letter-spacing: 0.05em;
	color: var(--text-gray);
	width: 82px;
}

.news-date-wrapper {
	display: flex;
	align-items: center;
	gap: 14.83px;
	flex-shrink: 0;
	/* width: 144px; */
}

.news-tag {
	font-weight: 600;
	font-size: 14.5px;
	line-height: 2em;
	letter-spacing: 0.05em;
	color: var(--text-gray);
}

.news-title {
	flex: 1;
	font-weight: 500;
	font-size: 16.965px;
	line-height: 1.6em;
	letter-spacing: 0.043em;
	color: var(--text-dark);
}
.dflex{
	display: flex;
	align-items: center;
}
.more-link {
	display: inline-flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	padding: 0 25px;
	width: 266px;
	height: 52px;
	background-color: var(--button-light);
	border-radius: 99px;
	text-decoration: none;
	color: var(--text-dark);
	font-weight: 600;
	font-size: 14.5px;
	letter-spacing: 0.05em;
	transition: transform 0.3s ease, background-color 0.3s ease;
	margin-top: 40px;
}

.more-link:hover {
	transform: translateX(5px);
	background-color: var(--button-bg);
}

.news-section .more-link {
	display: inline-flex;
	/* width: auto; */
	margin-top: 40px;
	margin-left: 0;
}

.more-link1 {
	display: inline-flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	padding: 0 25px;
	width: 266px;
	height: 52px;
	background-color: var(--button-light);
	border-radius: 99px;
	text-decoration: none;
	color: var(--text-dark);
	font-weight: 600;
	font-size: 14.5px;
	letter-spacing: 0.05em;
	transition: transform 0.3s ease, background-color 0.3s ease;
	margin-top: 40px;
}

.more-link1:hover {
	transform: translateX(5px);
	background-color: var(--button-bg);
}

/* Travel Tours Section 样式 */
.travel-tours-section {
	padding: 96px 0 0;
	background-color: var(--bg-color);
}

.travel-tours-section .container {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0;
	align-items: stretch;
	max-width: 1440px;
	padding: 0;
}

.travel-tours-content {
	padding: 60px 72px;
	background-color: var(--bg-color);
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	min-height: 445px;
}
.travel_d{
	position: relative;
	height: 100%;
}

.section-header {
	margin-bottom: 40px;
}

.section-title-large {
	font-weight: 500;
	font-size: 36px;
	line-height: 1.33em;
	letter-spacing: 0.017em;
	color: var(--text-dark);
	margin-bottom: 10px;
	white-space: no-wrap;
}

.section-subtitle-large {
    margin-left: 20px;
	font-weight: 500;
	font-size: 20px;
	line-height: 1em;
	letter-spacing: 0.036em;
	color: var(--text-dark);
}

.section-text {
	font-weight: 600;
	font-size: 14.5px;
	line-height: 2em;
	letter-spacing: 0.05em;
	color: var(--text-dark);
	text-align: justify;
	margin-bottom: 0;
}

.section-text p {
	margin-bottom: 40px;
}

.section-text .more-link {
	display: inline-flex;
	margin: 30px auto 0;
}

.travel-tours-content .section-text {
	display: flex;
	flex-direction: column;
	/* align-items: center; */
}

.travel-tours-content .section-text p {
	width: 100%;
}

/* Travel Tours 右侧图片区域 */
.travel-tours-images {
	display: flex;
	flex-direction: column;
	width: 100%;
	max-width: 712px;
}

.tour-image-item {
	position: relative;
	width: 100%;
	height: 445px;
	overflow: hidden;
}
.tour-image-item .swiper{
    height: 100%;
}
.tour-image-item:first-child {
	border-radius: 11.25px 0 0 0;
}

.tour-image-item:last-child {
	border-radius: 0 0 0 11.25px;
	border-top: none;
}

.tour-image-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	border-radius: 0;
}

.travel-tours-slider,
.transportation-slider,
.mice-slider {
	position: relative;
	width: 100%;
	height: 445.78px;
	border-radius: 11.25px 0 0 11.25px;
	overflow: hidden;
}

.slider-wrapper {
	position: relative;
	width: 100%;
	height: 100%;
}

.slider-item {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	opacity: 0;
	transition: opacity 1s ease-in-out;
}

.slider-item.active {
	opacity: 1;
}

.slider-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 10px 0 0 10px;
}

.slider-caption,
.image-caption {
	position: absolute;
	bottom: 10px;
	left: 5px;
	z-index: 99;
	color: var(--white);
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 10px;
}

.caption-text-vertical {
	font-weight: 500;
	font-size: 30px;
	line-height: 1em;
	letter-spacing: 0.05em;
	writing-mode: vertical-rl;
	text-orientation: upright;
	margin: 0;
	white-space: nowrap;
	height: auto;
}

.caption-text-horizontal {
	font-weight: 500;
	font-size: 16px;
	line-height: 1.4em;
	letter-spacing: 0.033em;
	margin: 0;
	margin-left: 65px;
	writing-mode: horizontal-tb;
	white-space: nowrap;
}

.slider-caption h3 {
	font-weight: 500;
	font-size: 45px;
	line-height: 1em;
	letter-spacing: 0.15em;
	writing-mode: vertical-rl;
	margin: 0 0 10px 0;
}

.slider-caption p {
	font-weight: 500;
	font-size: 22px;
	line-height: 1.4em;
	letter-spacing: 0.033em;
	margin: 0;
	writing-mode: horizontal-tb;
}

/* Transportation Section 样式 */
.transportation-section {
	padding: 48px 0 0;
	background-color: var(--bg-color);
}
.flexrr{
    flex-direction: row-reverse;
}

.transportation-section .container {
	display: flex;
	grid-template-columns: 1fr 1fr;
	gap: 50px;
	align-items: center;
}

.transportation-slider {
	border-radius: 0 10px 10px 0;
}

.transportation-slider .slider-item img {
	border-radius: 0 10px 10px 0;
}

/* MICE Section 样式 - 左侧图片，右侧文字 */
.mice-section {
	padding: 48px 0 0;
	background-color: var(--bg-color);
}

.mice-section .container {
	display: flex;
	grid-template-columns: 1fr 1fr;
	gap: 0;
	align-items: stretch;
	max-width: 1440px;
	padding: 0;
}

.mice-image {
	width: 100%;
	height: 445.78px;
	overflow: hidden;
	border-radius: 11.25px 0 0 11.25px;
}

.mice-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.mice-content {
	padding: 60px 72px;
	background-color: var(--bg-color);
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	min-height: 445.78px;
}

.mice-content .section-header {
	margin-bottom: 40px;
}

.mice-content .section-text {
	margin-bottom: 40px;
}

.mice-content .section-text p {
	width: 100%;
	margin-bottom: 0;
}

.mice-content .more-link {
	align-self: center;
	margin-top: 0;
}

/* Custom Travel Section 样式 - 左侧文字，右侧图片 */
.custom-travel-section {
	padding: 48px 0 0;
	background-color: var(--bg-color);
}

.custom-travel-section .container {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0;
	align-items: stretch;
	max-width: 1440px;
	padding: 0;
}

.custom-travel-content {
	padding: 60px 72px;
	background-color: var(--bg-color);
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	min-height: 445.78px;
}

.custom-travel-content .section-text {
	display: flex;
	flex-direction: column;
	/* align-items: center; */
}

.custom-travel-content .section-text p {
	width: 100%;
}
.syitem{
	margin-bottom: 34px;
	display: flex;
	align-items: center;
}
.syitem1{
    width: 25%;
	font-weight: 500;
	font-size: 20px;
	line-height: 60px;
	letter-spacing: 0.72px;
	text-align: center;
	color: #2D2D2D;
	cursor: pointer;
}
.syitem1.on{
	background-color: #F6F2EC;
	color: #A22324;	
}
.custom-travel-image {
	width: 100%;
	height: 445.78px;
	overflow: hidden;
	border-radius: 0 11.25px 11.25px 0;
}

.custom-travel-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* Gallery Section 样式 */
.gallery-section {
	padding: 96px 0 0;
	background-color: var(--bg-color);
}
.itbimg{
    margin-top: 16px;
}
.gallery-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 25px;
}

.gallery-item {
	position: relative;
	width: 100%;
	height: 414px;
	border-radius: 10px;
	overflow: hidden;
	cursor: pointer;
	transition: transform 0.3s ease;
}

.gallery-item:hover {
	transform: translateY(-5px);
}

.gallery-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.gallery-caption {
	position: absolute;
	bottom: 0;
	left: 0;
	color: var(--white);
}

.gallery-caption h3 {
	font-weight: 500;
	font-size: 35px;
	line-height: 1em;
	letter-spacing: 0.15em;
	writing-mode: vertical-rl;
}
.appoint{
	margin-top: 20px;
}
.appoint1{
	margin-top: 10px;
	display: flex;
	align-items: center;
}
.appoint1 a{
	display: flex;
	align-items: center;
	justify-content: space-between;
	text-decoration: none;
	width: 350px;
	height: 54px;
	border-radius: 27px;
	border: 1px solid #FFFFFF;
	padding: 0 20px;
	margin-right: 15px;
	font-weight: 600;
	font-size: 16px;
	letter-spacing: 0.72px;
	color: #FFFFFF;
	transition: all .5s;
}
.appoint1 a:hover{
    transform: translateY(-10px);
}

/* About Section 样式 */
.about-section {
	padding: 48px 0 0;
	background-color: var(--bg-color);
}

/* Reservation Section 样式 */
.reservation-section {
	padding: 96px 0 0;
	background-color: transparent;
	position: relative;
	min-height: 435px;
}

.reservation-section .container {
	max-width: 1440px;
	padding: 0;
}

.reservation-section .reservation-content {
	position: relative;
	width: 1400px;
	max-width: 100%;
	margin: 0 auto;
	padding: 38px 40px 20px;
	background: linear-gradient(rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.3)),
		url('../images/aadb6c61fad1a2ed2ae942468f7ff97a455edf2b.jpg') center/cover no-repeat;
	border-radius: 20px;
	color: var(--white);
	/* min-height: 435px; */
	/* display: flex;
	flex-direction: column;
	justify-content: space-between; */
}

.reservation-title {
	display: flex;
	align-items: center;
	font-weight: 500;
	font-size: 56px;
	line-height: 1em;
	letter-spacing: 0.013em;
	margin-bottom: 30px;
}

.reservation-subtitle {
	margin-left: 12px;
	margin-top: 24px;
	font-weight: 500;
	font-size: 20px;
	line-height: 1em;
	letter-spacing: 0.036em;
}

.reservation-inputs {
	display: flex;
	flex-direction: column;
	gap: 15px;
	margin-bottom: 40px;
}

.reservation-input-wrapper {
	position: relative;
	width: 280px;
	max-width: 100%;
}

.reservation-input {
	width: 100%;
	padding: 11px 50px 11px 21px;
	border: 1px solid var(--white);
	border-radius: 1123.875px;
	background-color: transparent;
	color: var(--white);
	font-weight: 600;
	font-size: 16px;
	line-height: 2em;
	letter-spacing: 0.045em;
	outline: none;
	transition: background-color 0.3s ease, border-color 0.3s ease;
}

.reservation-input::placeholder {
	color: var(--white);
	opacity: 1;
}

.reservation-input:focus {
	background-color: rgba(255, 255, 255, 0.1);
	border-color: rgba(255, 255, 255, 0.8);
}

.reservation-input-wrapper .input-arrow {
	position: absolute;
	right: 21px;
	top: 50%;
	transform: translateY(-50%);
	pointer-events: none;
	width: 22px;
	height: 20px;
}

.contact-info {
	margin-top: 16px;
}

.contact-label {
	font-weight: 600;
	font-size: 14.5px;
	letter-spacing: 0.05em;
	color: #D6CFBE;
}

.contact-tel {
	font-weight: 600;
	font-size: 18px;
	line-height: 2em;
	letter-spacing: 0.04em;
	color: #ffffff;
}
.contact-tel span{
	color: #ffffff;
}
.contact-tel span:first-child {
	font-family: 'Zen Old Mincho', serif;
}

/* Footer 样式 */
.footer {
	margin-top: 48px;
	background-color: var(--bg-color);
	padding: 60px 0 70px;
}
.goTop{
	position: fixed;
	right: 10px;
	bottom: 200px;
	z-index: 96;
	font-size: 0;
}
.footer-content {
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 72px;
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
}

/* 左侧：Logo和公司信息 */
.footer-left {
	display: block;
	flex-direction: column;
	gap: 15px;
}

.footer-logo {
	margin-bottom: 47px;
}

.footer-logo img {
	width: auto;
	height: 70px;
	display: block;
	margin: 0 auto;
}

.footer-company {
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
	font-size: 16px;
	line-height: 1.8em;
	letter-spacing: 0.03em;
	color: var(--text-dark);
	margin: 0;
}

.footer-license {
	font-weight: 400;
	font-size: 14px;
	line-height: 1.8em;
	letter-spacing: 0.03em;
	color: #2A2C2C;
	margin: 0;
}
.footeropyright{
	margin-top: 90px;
	font-weight: 600;
	font-size: 12.94px;
	line-height: 25.88px;
	letter-spacing: 0.72px;
	color: #3E4048;
}
.dbez{
	margin-top: 40px;
	text-align: center;
}
.dbez a{
	margin: 0 10px;
	font-weight: 600;
	font-size: 12px;
	line-height: 32px;
	letter-spacing: 0.72px;
	color: #3E4048;
}
.footer-language {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-top: 5px;
}

.footer-language a{
    color: #3E4048;
    text-decoration: none;
}

.footer-lang-link {
	color: var(--text-dark);
	text-decoration: none;
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
	font-size: 14px;
	line-height: 2em;
	letter-spacing: 0.05em;
	transition: opacity 0.3s ease;
}

.footer-lang-link:hover {
	opacity: 0.7;
}

.footer-lang-link.active {
	font-weight: 600;
}

.footer-language span {
	color: var(--text-dark);
	font-size: 14px;
}

.footer-copyright {
	font-size: 12px;
	line-height: 1.8em;
	letter-spacing: 0.03em;
	color: var(--text-dark);
	margin: 20px 0 0 0;
}

/* 中间：导航链接 */
.footer-middle {
	/* display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 40px; */
}

.footer-column {
	display: flex;
	align-items: center;
	justify-content: space-between;
	min-width: 480px;
	/* flex-direction: column;
	gap: 8px; */
}

.footer-link {
	display: block;
	color: var(--text-dark);
	text-decoration: none;
	font-weight: 600;
	font-size: 14px;
	line-height: 2em;
	letter-spacing: 0.045em;
	transition: opacity 0.3s ease;
}

.footer-link:hover {
	opacity: 0.7;
}

/* 右侧：联系信息和社交媒体 */
.footer-right {
	display: block;
	flex-direction: column;
	gap: 15px;
}
.footer-right .footer-company-name{
	margin-top: 40px;
	font-weight: 600;
	font-size: 14px;
	line-height: 23px;
	letter-spacing: 0.72px;
	text-align: right;
	color: #3E4048;
}
.footer-info {
}

.footer-company-name {
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
	font-size: 24px;
	line-height: 27px;
	letter-spacing: 0.03em;
	color: #2A2C2C;
	margin: 0 0 5px 0;
}

.footer-address {
	font-weight: 400;
	font-size: 13px;
	line-height: 23px;
	letter-spacing: 0.03em;
	color: #3E4048;
	margin: 0;
	text-align: right;
}

.footer-address p {
	margin: 0;
}

.google-map-link {
    margin-right: 20px;
	color: var(--text-dark);
	text-decoration: none;
	font-weight: 400;
	font-size: 14px;
	line-height: 1.8em;
	letter-spacing: 0.05em;
	border-bottom: 1px dashed var(--text-dark);
	display: inline-block;
	width: fit-content;
	margin-top: 5px;
	transition: opacity 0.3s ease;
}

.google-map-link:hover {
	opacity: 0.7;
}

.footer-contact {
	font-weight: 600;
	font-size: 13px;
	line-height: 23px;
	letter-spacing: 0.72px;
	text-align: right;
	color: #3E4048;
}

.footer-contact p {
	font-weight: 600;
	font-size: 13px;
	line-height: 23px;
	letter-spacing: 0.72px;
	text-align: right;
	color: #3E4048;
}

.footer-social {
	display: flex;
	align-items: center;
	gap: 15px;
	margin-top: 15px;
}


.social-icon {
	width: 24px;
	height: 24px;
	color: var(--text-dark);
	transition: all 0.3s ease;
}

.social-icon:hover {
	opacity: 0.7;
	transform: translateY(-3px);
}

.social-icon svg,
.social-icon img {
	width: 100%;
	height: 100%;
	display: block;
}
.wap{
	display: none !important;
}
.innerBanner{
	padding: 25px 25px 0;
	font-size: 0;
	text-align: right;
	position: relative;
}
.innerBanner.pt0{
	padding: 0;
}
.innerBanner img{
	display: inline-block;
	margin: 0 auto;
	width: 100%;
	max-width: 965px;
	height: 465px;
	border-radius: 10px 0 0 10px;
}

.innerBanner1{
	position: absolute;
	left: 50%;
	bottom: 40px;
	z-index: 9;
	width: 100%;
	transform: translateX(-50%);
	text-align: left;
	padding-left: 105px;
}
.innerBanner2{
	font-weight: 500;
	font-size: 32px;
	line-height: 56px;
	letter-spacing: 0.72px;
	color: #ffffff;
}
.innerBanner2.black{
	color: #3E4048;
}
.innerLine{
	margin-top: 25px;
	width: 227px;
	height: 1px;
	background-color: #939393;
}
.innerBanner3{
	margin-top: 20px;
	font-weight: 500;
	font-size: 14.5px;
	line-height: 29px;
	letter-spacing: 0.72px;
	color: #ffffff;
}
.innerBanner3.black{
	color: #3E4048;
}
.inbbanner{
	display: flex;
	justify-content: flex-end;
}
.inbbanner .swiper{
	width: 100%;
    max-width: 965px;
	margin: unset;
}
.inabanner{
	display: flex;
	justify-content: flex-end;
}
.inabanner .swiper{
	width: 100%;
    max-width: 965px;
	margin: unset;
}
.mt30{
	margin-top: 30px;
}
.texr{
	justify-content: flex-end;
}
/* 动画效果 */
@keyframes fadeInUp {
	from {
		opacity: 0;
		transform: translateY(30px);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes fadeInUp1 {
	from {
		opacity: 0;
		transform: translate(-50%, 30px);
	}

	to {
		opacity: 1;
		transform: translate(-50%, -50%);
	}
}


@keyframes fadeInRight {
	from {
		opacity: 0;
		transform: translateY(-50%) translateX(50px);
	}

	to {
		opacity: 1;
		transform: translateY(-50%) translateX(0);
	}
}

@keyframes bounce {

	0%,
	100% {
		transform: translateY(0);
	}

	50% {
		transform: translateY(10px);
	}
}

@keyframes bounce-arrow {

	0%,
	100% {
		transform: translateY(0);
	}

	50% {
		transform: translateY(5px);
	}
}

/* 响应式设计 */
@media (max-width: 1320px) {
	.header-container{
		gap: 20px;
		padding: 0 20px;
	}
	.nav-menu{
		gap: 10px;
	}
	.user-icon a {
	    margin-left: 16px;
	}
	.user-icon a:first-child{
		margin-left: 0;
	}
	.nav-link {
	    font-size: 12px;
	    letter-spacing: 0;
	}
}
@media (max-width: 1200px) {

	.travel-tours-section .container,
	.transportation-section .container,
	.mice-section .container,
	.custom-travel-section .container {
	    display: block;
		grid-template-columns: 1fr;
		gap: 0;
	}
    .transportation-section .container{
        padding: 0;
    }
    .travel-tours-content, .transportation-content{
        padding: 0 20px;
    }
	.travel-tours-slider,
	.transportation-slider,
	.mice-slider {
		height: 400px;
		padding-right: 20px;
	}
    .swiperaaa {
        overflow: hidden;
    }
	.mice-image,
	.custom-travel-image {
		height: 400px;
		border-radius: 0;
		padding-left: 20px;
	}

	.mice-content,
	.custom-travel-content {
		min-height: auto;
		padding: 40px 20px;
	}

	.reservation-section .reservation-content {
		width: calc(100% - 80px);
	}
}
@media (max-width: 900px) {

	.innerBanner img{
		height: auto;
	}
	
	.innerBanner .swiper img{
		height: 465px;
	}
	.tour-image-item:last-child{
		padding: 0 2%;
	}
	.goTop img{
		width: 36px;
	}
	.pc{
		display: none !important;
	}
	.wap{
		display: block !important;
	}
	.travel-tours-images{
		max-width: 100%;
	}
	.travel-tours-section .container{
		display: block;
	}
	.travel-tours-content {
		padding: 15px;
		min-height: 10px;
	}
	.section-header {
		margin-bottom: 20px;
	}
	.more-link1{
		margin-top: 0;
	}
	.tour-image-item{
	    margin-top: 40px;
		height: 300px;
		padding-left: 50px;
	}
	.image-caption{
	    left: 60px;
	}
	.caption-text-vertical{
		font-size: 18px;
	}
	.caption-text-horizontal {
		font-size: 14px;
		margin-left: 30px;
	}
	.section-header{
		margin-top: 16px;
	}
	.travel-tours-slider, .transportation-slider, .mice-slider{
		height: auto;
	}
	.syitem{
	    overflow-x: scroll;
	    display: block;
	    white-space: nowrap;
	}
	.syitem .swiper {
		padding-right: 5%;
	}
	.syitem1 {
	    display: inline-block;
	    width: 200px;
		font-size: 14px;
		line-height: 50px;
		letter-spacing: 0;
	}
	.itbimg .swiper{
	    padding-right: 15%;
	}
	.gallery-caption h3{
	    font-size: 20px;
	}
	.appoint{
		margin-top: 20px;
	}
	.appoint1 a{
		font-size: 12px;
	}
	.innerBanner{
		padding: 15px 0 0;
	}
	.innerBanner.pt0{
		padding: 15px 20px 0;
	}
	.innerBanner1 {
		bottom: 20px;
		padding-left: 30px;
	}
	.innerBanner2 {
		font-size: 20px;
		line-height: 1;
	}
	.innerLine{
		width: 180px;
	}
	.innerBanner3 {
		margin-top: 10px;
		line-height: 1;
	}
	.headTc{
	    width: 100%;
	    padding: 20px;
	}
	.headTc2 a{
	    font-size: 12px;
	    line-height: 21px;
	    margin-top: 0;
	}
	.headTc3 {
        margin-top: 0;
        margin-bottom: 0;
    }
    .headTc4 span {
        /* font-size: 18px;
        line-height: 26px; */
    }
    .headTc5 a {
        height: 32px;
        font-size: 12px;
    }
    .headTc12{
        margin-top: 20px;
    }
    .headTc12 a{
        margin: 0 10px;
    }
    .logo a img{
        /* width: 40px; */
    }
    .user-icon a{
        margin-left: 15px;
    }
    .transportation-slider{
        margin-top: 20px;
		padding: 0 2%;
    }
	.footer{
		padding: 30px 0;
		margin-top: 30px;
	}
	.footer-content{
		flex-direction: column;
	}
    .footer-left{
		width: 100%;
        text-align: center;
    }
	.footeropyright{
		margin-top: 20px;
	}
	.footer-middle{
		width: 100%;
		margin-top: 30px;
	}
	.footer-right{
		width: 100%;
	}
	.footer-logo{
		margin-bottom: 20px;
	}
	.footer-column{
		min-width: 10px;
	}
	.footer-column img{
		display: none;
	}
    .footer-logo img{
        margin: 0 auto;
    }
    .footer-language{
        justify-content: center;
    }
    .innerBanner2.black{
        color: #ffffff;
    }
    .innerBanner3.black{
        color: #ffffff;
    }
	.footer-right .footer-company-name{
		text-align: center;
	}
	.footer-address{
		text-align: center;
	}
	.footer-contact{
		text-align: center;
	}
}
@media (max-width: 768px) {
	.header-container {
		padding: 0 20px;
		grid-template-columns: auto 1fr auto;
		gap: 20px;
	}

	.nav-menu {
		position: fixed;
		top: 91px;
		left: -100%;
		width: 100%;
		height: calc(100vh - 91px);
		background: rgba(51, 51, 51, 0.98);
		flex-direction: column;
		align-items: flex-start;
		padding: 40px 20px;
		gap: 20px;
		transition: left 0.3s ease;
		overflow-y: auto;
		justify-content: flex-start;
		grid-column: 1 / -1;
		z-index: 999;
	}

	.nav-menu.active {
		left: 0;
	}

	.nav-dropdown {
		flex-direction: column;
		gap: 15px;
		width: 100%;
	}

	.menu-toggle {
		display: block;
	}

	.header-right {
		gap: 10px;
	}
	.header-left {
		display: flex;
	}

	.menu-toggle.active svg line {
		stroke: var(--white);
	}
	.header {
		height: 91px;
		padding: 15px 0;
	}
	.hero{
		margin: 15px 15px 0;
		height: 300px;
		/* min-height: 489px; */
	}
	.hero-content{
	    position: unset;
	}
	.hero-title {
		font-size: 28px;
	}
	.logo-img {
		/* width: 80px; */
	}
	.logo-text {
		font-size: 14px;
	}
	.hero-text-left {
		left: 20px;
		bottom: 72px;
	}

	.hero-logo {
	    display: none;
		top: 15%;
	}

	.hero-bottom {
	    display: none;
		bottom: 30px;
	}

	.section-title,
	.section-title-large {
		font-size: 32px;
	}

	.gallery-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 15px;
	}

	.gallery-item {
		height: 180px;
	}

	.reservation-section {
		padding: 40px 0 0;
		min-height: 10px;
	}
    
	.reservation-section .reservation-content {
		width: 100%;
		margin: 0 20px;
		padding: 30px 25px;
		min-height: auto;
	}

	.footer-content {
		/* grid-template-columns: 1fr;
		gap: 40px; */
		padding: 0;
	}

	.footer-middle {
		grid-template-columns: 1fr;
		gap: 30px;
		text-align: center;
	}
	.footer-info{
	    text-align: center;
	}
	.google-map-link{
	    display: block;
	    margin: 10px auto 0;
	}
    
    
	.news-section,
	.travel-tours-section,
	.transportation-section,
	.mice-section,
	.custom-travel-section,
	.gallery-section,
	.about-section {
		padding: 20px 0;
	}

	.news-section .container {
		flex-direction: column;
		gap: 20px;
		padding: 0 20px;
	}

	.news-header {
		width: 100%;
	}

	.news-item {
		flex-direction: column;
		gap: 10px;
	}

	.news-date-wrapper {
		width: 100%;
	}

	.travel-tours-content,
	.transportation-content {
		order: 2;
	}

	.travel-tours-slider,
	.transportation-slider {
		order: 1;
	}

	.custom-travel-content {
		order: 1;
	}

	.custom-travel-image {
		/* order: 2; */
		padding: 0 2%;
	}

	.mice-image {
		order: 1;
	}

	.mice-content {
		order: 2;
	}

	.mice-image,
	.custom-travel-image {
		border-radius: 0;
		height: auto;
	}

	.mice-content,
	.custom-travel-content {
		padding: 20px 20px;
	}
}

@media (max-width: 480px) {
	.hero-background {
		/* margin: 10px; */
		border-radius: 15px;
	}

	.gallery-grid {
		grid-template-columns: 1fr;
	}

	.hero-title {
		font-size: 20px;
	}
	.hero-title br{
	    display: none;
	}
	.hero-description{
	    font-size: 10px;
	}

	.section-title,
	.section-title-large {
		font-size: 24px;
	}

	.hero-cta {
		padding: 10px 25px;
		font-size: 16px;
	}

	.reservation-section .reservation-content {
		padding: 25px 20px;
		/* margin: 0 10px; */
	}

	.reservation-title {
		font-size: 30px;
	}

	.footer {
		padding: 30px 0;
	}
	
	.footer-content {
		padding: 0;
	}

	.footer-social {
		gap: 10px;
		justify-content: center;
	}

	.social-icon {
		width: 20px;
		height: 20px;
	}
}

/* 滚动动画 */
.fade-in {
	opacity: 0;
	transform: translateY(30px);
	transition: opacity 0.6s ease, transform 0.6s ease;
}

.fade-in.visible {
	opacity: 1;
	transform: translateY(0);
}

/* 移动端菜单动画 */
@media (max-width: 768px) {
	.nav-menu {
		box-shadow: 2px 0 10px rgba(0, 0, 0, 0.3);
	}

	.nav-link {
		font-size: 16px;
		padding: 10px 0;
		width: 100%;
		border-bottom: 1px solid rgba(255, 255, 255, 0.1);
	}
}

/* 图片加载优化 */
img {
	max-width: 100%;
	height: auto;
	display: block;
}

/* 响应式优化 */
@media (max-width: 1024px) {
	.reservation-section .reservation-content {
		width: calc(100% - 40px);
	}

}

/* ============================================
   PEGASUSについて 页面样式
   ============================================ */

/* Page Banner */
.about-page-banner {
	position: relative;
	width: 100%;
	height: 581px;
	margin: 25px;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	padding-top: 91px;
}

.about-page-banner .banner-background {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: linear-gradient(rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.3)),
		url('../images/9ca614fed4f02241a9b4b86311798fcaf7a9c40d.jpg') center/cover no-repeat;
	border-radius: 0;
	z-index: 1;
	border-radius: 30px;
}

.about-page-banner .banner-content {
	position: relative;
	z-index: 2;
	width: 100%;
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 105px;
	color: var(--white);
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	padding-bottom: 120px;
}

.breadcrumb-nav {
	display: flex;
	align-items: center;
	gap: 5px;
	font-weight: 400;
	font-size: 12px;
	line-height: 1.5em;
	letter-spacing: 0.125em;
	padding: 0 100px;
}

.breadcrumb-link {
	color: var(--white);
	text-decoration: none;
	transition: opacity 0.3s ease;
}

.breadcrumb-link:hover {
	opacity: 0.7;
}

.breadcrumb-separator {
	color: var(--black);
}

.breadcrumb-current {
	color: var(--black);
}

/* Page Content */
.about-page-content {
	padding: 0 0 0;
	background-color: var(--bg-color);
}

.about-page-content .container {
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 105px;
}

.about-intro {
	margin-top: 60px;
	margin-bottom: 40px;
}

.about-main-title {
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
	font-size: 32px;
	lineHeight: 1.75em;
	letter-spacing: 0.022em;
	color: var(--text-dark);
	margin: 0 0 8px;
}

.about-main-subtitle {
	font-weight: 500;
	font-size: 32px;
	line-height: 1.75em;
	letter-spacing: 0.022em;
	color: var(--text-dark);
	margin: 0;
}

.about-vision-section {
	margin-top: 131px;
	display: flex;
	justify-content: flex-end;
	margin-bottom: 96px;
}
.abimg{
	/* max-width: 1440px; */
	margin: 60px auto 0;
}
.abimg .swiper{
	padding: 0 20%;
	overflow: hidden;
}
.abimg .swiper-wrapper{
	display: flex;
	align-items: center;
}
.abimg .swiper-slide{
	width: 100%;
	flex-shrink: 0;
	display: flex;
	justify-content: center;
}
.abimg img{
	width: 100%;
	max-width: 100%;
	display: block;
	object-fit: cover;
}
.about-vision-text {
	max-width: 647px;
}
.abcont{
	padding: 41px 0 48px;
	max-width: 1440px;
	margin: 0 auto;
}
.abcont1{
	font-weight: 500;
	font-size: 32px;
	line-height: 56px;
	letter-spacing: 0.72px;
	color: #3E4048;
}
.abcont2{
	margin-top: 30px;
	font-weight: 600;
	font-size: 14px;
	line-height: 29px;
	letter-spacing: 0.72px;
	text-align: justify;
	color: #3E4048;
}
.about-section-title {
	font-weight: 500;
	font-size: 32px;
	line-height: 1.75em;
	letter-spacing: 0.022em;
	color: var(--text-dark);
	margin-bottom: 16px;
}

.about-section-body {
	font-weight: 400;
	font-size: 14px;
	line-height: 2.07em;
	letter-spacing: 0.05em;
	color: var(--text-dark);
	margin: 0;
}

.about-gallery {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 18px;
}

.about-gallery-item {
	position: relative;
	height: 300px;
	border-radius: 10px;
	overflow: hidden;
}

.about-gallery-image {
	width: 100%;
	height: 100%;
	background-size: cover;
	background-position: center;
	border-radius: 10px;
}

.about-gallery-image-1 {
	background-image: url('../images/bf5ff657a17623882a678ead52b64ca1009fa17e.jpg');
}

.about-gallery-image-2 {
	background-image: url('../images/5f847e3fe536c7d2bef319bf50567f952f2349d3.jpg');
}

.about-gallery-image-3 {
	background-image: url('../images/ff4b3f60665978275a3f7add93d06bc88956198e.jpg');
}

.about-gallery-deco {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 60%;
	height: 45%;
	background: rgba(237, 229, 216, 0.85);
	border-radius: 0 10px 0 0;
}

.about-description-section {
	margin-bottom: 80px;
}

.about-description-paragraph {
	font-weight: 600;
	font-size: 14px;
	line-height: 2.07em;
	letter-spacing: 0.052em;
	color: var(--text-dark);
	margin: 0 0 32px;
}

.company-overview-section {
	margin-bottom: 40px;
}

.company-overview-title {
	font-weight: 600;
	font-size: 32px;
	line-height: 0.92em;
	color: var(--text-dark);
	margin: 0 0 24px;
}

.company-overview-table {
	background-color: #E0DACF;
	padding: 40px 48px;
}

.company-row {
	display: grid;
	grid-template-columns: 160px 1fr;
	align-items: center;
	padding: 18px 0;
	border-bottom: 1px solid #272727;
}

.company-row:last-child {
	border-bottom: none;
}

.company-label {
	font-weight: 400;
	font-size: 20px;
	line-height: 1.8em;
	letter-spacing: 0.056em;
	color: #000000;
}

.company-value {
	font-weight: 400;
	font-size: 20px;
	line-height: 1.8em;
	letter-spacing: 0.056em;
	color: #000000;
}

/* Left Sidebar */
.about-sidebar {
	background-color: var(--white);
	border-radius: 10px;
	padding: 20px 0;
	box-shadow: 0px 0px 30px 0px rgba(0, 0, 0, 0.1);
	transition: all 0.3s ease;
	height: fit-content;
	min-width: 300px;
}

.about-sidebar.collapsed {
	min-width: 60px;
	width: 60px;
}

.sidebar-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 0 20px 20px 20px;
	border-bottom: 1px solid #E4E4E4;
	cursor: pointer;
}

.sidebar-title {
	font-weight: 500;
	font-size: 18px;
	line-height: 1.5em;
	color: var(--text-dark);
	margin: 0;
}

.about-sidebar.collapsed .sidebar-title {
	display: none;
}

.sidebar-toggle-btn {
	background: none;
	border: none;
	cursor: pointer;
	padding: 5px;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: transform 0.3s ease;
}

.about-sidebar:not(.collapsed) .sidebar-toggle-btn {
	transform: rotate(180deg);
}

.about-sidebar.collapsed .sidebar-toggle-btn {
	transform: rotate(0deg);
}

.toggle-icon {
	width: 22px;
	height: 22px;
}

.sidebar-content {
	transition: all 0.3s ease;
	overflow: hidden;
	max-height: 1000px;
	opacity: 1;
}

.about-sidebar.collapsed .sidebar-content {
	max-height: 0;
	padding: 0;
	opacity: 0;
	overflow: hidden;
}

.sidebar-nav {
	margin-bottom: 12px;
}

.sidebar-link {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 10px 20px;
	font-weight: 500;
	font-size: 16px;
	line-height: 1.81em;
	letter-spacing: 0.045em;
	color: var(--black);
	text-decoration: none;
	transition: background-color 0.3s ease, color 0.3s ease;
	border-radius: 0;
	background-color: #F6F2EC;
	margin-bottom: 0;
}
.sidebar-link a{
	text-decoration: none;
}
.sidebar-link:hover {
	background-color: rgba(0, 0, 0, 0.05);
}

.sidebar-link.active{
	color: var(--accent-red);
	background-color: #F6F2EC;
}
.sidebar-link.active .narrow{
	display: none;
}
.sidebar-link.active .narrow1{
	display: block;
}
.sidebar-link .chevron-icon {
	flex-shrink: 0;
	width: 22px;
	height: 22px;
}

.about-sidebar.collapsed .chevron-icon {
	display: none;
}

.sidebar-filters {
	display: none;
}
.sidebar-nav.active .sidebar-filters {
	display: block;
}
.filter-group {
	margin-top: 14px;
}

.filter-group:last-child {
	margin-bottom: 0;
}

.filter-group-title {
	display: none;
}
.ggdate{
	display: none;
}
.filter-group.active .ggdate{
	display: block;
}
.filter-items {
	display: flex;
	flex-direction: column;
	gap: 0;
}

.filter-tag {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 10px 20px;
	background-color: #E3DACA;
	border: none;
	border-radius: 0;
	font-weight: 500;
	font-size: 16px;
	line-height: 1.81em;
	letter-spacing: 0.045em;

	cursor: pointer;
	text-align: left;
	transition: background-color 0.3s ease, color 0.3s ease;
	width: 100%;
}
.filter-tag a{
	color: var(--black);
	text-decoration: none;
}
.filter-tag:hover {
	background-color: rgba(0, 0, 0, 0.05);
}
.filter-group a{
	text-decoration: none;
}
.filter-tag1 {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 10px 20px;
	margin-top: 6px;
	border: none;
	border-radius: 0;
	background-color: rgba(0, 0, 0, 0);
	font-weight: 500;
	font-size: 16px;
	line-height: 1.81em;
	letter-spacing: 0.045em;

	cursor: pointer;
	text-align: left;
	width: 100%;
}
.filter-tag1 a{
	color: var(--black);
	text-decoration:none;
}
.filter-tag.active{
	color: var(--accent-red);
	background-color: #E3DACA;
	text-decoration: none;
}
.filter-tag1.active{
	color: var(--accent-red);
}
.filter-tag.active .narrow{
	display: none;
}
.filter-tag.active .narrow1{
	display: block;
}

.filter-tag svg {
	flex-shrink: 0;
	width: 22px;
	height: 22px;
}

.filter-group {
	margin-bottom: 0;
}

.filter-group:first-child {
	margin-bottom: 0;
}

/* Right Main Content */
.about-main-content {
	background-color: var(--white);
	border-radius: 10px;
	padding: 60px;
	box-shadow: 0px 0px 30px 0px rgba(0, 0, 0, 0.1);
}

.about-header {
	margin-bottom: 40px;
}

.about-title {
	font-weight: 500;
	font-size: 35px;
	line-height: 1.6em;
	letter-spacing: 0.02em;
	color: var(--text-dark);
	margin: 0 0 10px 0;
}

.about-subtitle {
	font-weight: 500;
	font-size: 14.5px;
	line-height: 2em;
	letter-spacing: 0.05em;
	color: var(--text-dark);
	margin: 0;
}

.about-description {
	margin-bottom: 40px;
}

.about-description p {
	font-weight: 400;
	font-size: 14px;
	line-height: 2.07em;
	text-align: justify;
	color: var(--text-dark);
	margin: 0;
}

.about-content-text {
	margin-top: 40px;
}

.about-content-text p {
	font-weight: 400;
	font-size: 14px;
	line-height: 2.07em;
	text-align: justify;
	color: var(--text-dark);
	margin: 0;
}

/* Description Section */
.description-section {
	padding: 0 137px;
	margin-bottom: 40px;
}

.description-text {
	font-weight: 400;
	font-size: 14px;
	line-height: 2.07em;
	text-align: justify;
	color: var(--text-dark);
	margin: 0;
}

/* Filter Section */
.filter-section {
	padding: 0 137px;
	margin-bottom: 40px;
}

.filter-buttons {
	display: flex;
	gap: 173px;
	margin-bottom: 30px;
}

.filter-btn {
	padding: 10px 20px;
	background-color: #F6F2EC;
	border: none;
	border-radius: 0;
	font-weight: 500;
	font-size: 16px;
	line-height: 1.81em;
	letter-spacing: 0.045em;
	color: var(--black);
	cursor: pointer;
	transition: background-color 0.3s ease, color 0.3s ease;
}

.filter-btn.active {
	color: var(--accent-red);
}

.filter-btn:hover {
	background-color: rgba(0, 0, 0, 0.05);
}

.filter-tags {
	display: flex;
	gap: 173px;
}

.filter-tag-group {
	display: flex;
	gap: 0;
}

.filter-tag {
	padding: 10px 20px;
	background-color: #E3DACA;
	border: none;
	border-radius: 0;
	font-weight: 500;
	font-size: 16px;
	line-height: 1.81em;
	letter-spacing: 0.045em;
	color: var(--black);
	cursor: pointer;
	transition: background-color 0.3s ease, color 0.3s ease;
}

.filter-tag.active {
	color: var(--accent-red);
}

.filter-tag:hover {
	background-color: rgba(0, 0, 0, 0.05);
}

/* Tour List Section */
.tour-list-section {
	padding: 0 137px;
}

.section-heading {
	font-weight: 500;
	font-size: 32px;
	line-height: 1.75em;
	letter-spacing: 0.023em;
	color: var(--text-dark);
	margin-bottom: 40px;
}

.tour-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 12px;
	margin-bottom: 60px;
}

/* Tour Card */
.tour-card {
	background-color: var(--white);
	border-radius: 10px;
	overflow: hidden;
	box-shadow: 0px 0px 30px 0px rgba(0, 0, 0, 0.1);
}

.tour-card-image {
	position: relative;
	width: 100%;
	height: 229.83px;
	overflow: hidden;
}

.tour-card-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.tour-card-tag {
	position: absolute;
	bottom: 10px;
	left: 50%;
	transform: translateX(-50%);
	font-weight: 400;
	font-size: 14px;
	line-height: 1em;
	letter-spacing: 0.071em;
	color: var(--white);
}

.tour-card-content {
	padding: 30px;
	position: relative;
}

.tour-card-title {
	font-weight: 700;
	font-size: 20px;
	line-height: 1.5em;
	color: var(--black);
	margin: 0 0 15px 0;
}

.tour-card-meta {
	display: flex;
	align-items: center;
	gap: 30px;
	margin-bottom: 8px;
}

.tour-location {
	display: flex;
	align-items: center;
	gap: 5px;
	font-weight: 400;
	font-size: 12px;
	line-height: 1.5em;
	color: #6E6E6E;
}

.tour-capacity {
	font-weight: 400;
	font-size: 16px;
	line-height: 1.5em;
	color: #6E6E6E;
}

.tour-card-divider {
	width: 100%;
	height: 1px;
	background-color: #E4E4E4;
	margin: 15px 0;
}

.tour-card-description {
	font-weight: 500;
	font-size: 16px;
	line-height: 1.5em;
	color: #6E6E6E;
	margin: 0 0 15px 0;
}

.tour-card-footer {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-top: 20px;
}

.tour-card-button {
	display: inline-block;
	padding: 9px 10px;
	background-color: #1E1E1E;
	border-radius: 2px;
	color: var(--white);
	font-weight: 700;
	font-size: 14px;
	line-height: 1em;
	text-decoration: none;
	transition: opacity 0.3s ease;
}

.tour-card-button:hover {
	opacity: 0.8;
}

.tour-card-price {
	font-weight: 700;
	font-size: 25px;
	line-height: 1.5em;
	color: var(--black);
	text-align: right;
}

.tour-card-duration {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px 20px;
	background-color: var(--white);
	border: 1px solid #DFDFDF;
	border-radius: 0;
	font-weight: 400;
	font-size: 14px;
	line-height: 1.5em;
	color: #6E6E6E;
	margin-top: 15px;
}

.tour-card-guide {
	position: absolute;
	top: 146px;
	right: 112px;
}

/* Pagination */
.pagination {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 50px;
	margin-top: 60px;
}
.pagination a{
	font-weight: 600;
	font-size: 16px;
	line-height: 29px;
	letter-spacing: 0.72px;
	color: #000000;
	text-decoration: none;
	display: inline-block;
	padding: 0 6px;
}
.pagination a.on{
	border-bottom: 1px solid #000000;
}
.pagination-btn {
	font-weight: 600;
	font-size: 16px;
	line-height: 1.81em;
	letter-spacing: 0.045em;
	color: var(--black);
	background: none;
	border: none;
	cursor: pointer;
	transition: opacity 0.3s ease;
}

.pagination-btn:hover {
	opacity: 0.7;
}

.pagination-numbers {
	display: flex;
	gap: 50px;
}

.pagination-number {
	font-weight: 600;
	font-size: 16px;
	line-height: 1.81em;
	letter-spacing: 0.045em;
	color: var(--black);
	background: none;
	border: none;
	cursor: pointer;
	transition: opacity 0.3s ease;
}

.pagination-number.active {
	color: var(--black);
}

.pagination-number:hover {
	opacity: 0.7;
}

.pagination-divider {
	width: 20px;
	height: 1px;
	background-color: var(--black);
	margin: 0 50px;
}

/* Reservation Sidebar - Fixed Position for this page */
.reservation-sidebar {
	position: fixed;
	right: 20px;
	top: 50%;
	transform: translateY(-50%);
	width: 400px;
	max-width: calc(100vw - 40px);
	background: linear-gradient(rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.3)),
		url('../images/aadb6c61fad1a2ed2ae942468f7ff97a455edf2b.jpg') center/cover no-repeat;
	border-radius: 20px;
	padding: 35px 40px;
	color: var(--white);
	z-index: 999;
}

/* 响应式设计 - About Page */
@media (max-width: 1024px) {
	.about-page-content .container {
		padding: 0 40px;
	}

	.about-vision-section {
		grid-template-columns: 1fr;
		gap: 40px;
	}

	.about-gallery-item {
		height: 260px;
	}
	.abcont{
		padding: 30px 0;
	}
	.abcont1{
		font-size: 20px;
	}


}

@media (max-width: 768px) {
	.about-page-banner {
		height: 400px;
	}

	.about-page-banner .banner-content {
		padding: 0 20px 80px;
	}

	.about-main-title {
		font-size: 28px;
	}

	.about-page-content .container {
		padding: 0 20px;
	}

	.about-vision-section {
		gap: 30px;
	}

	.about-gallery-item {
		height: 220px;
	}

	.company-overview-table {
		padding: 24px 20px;
	}

	.company-row {
		grid-template-columns: 1fr;
		row-gap: 4px;
	}
}

/* ============================================
   旅行ツアー 页面样式
   ============================================ */

/* Tour Page Banner */
.tour-page-banner {
	position: relative;
	width: 100%;
	height: 581px;
	margin-top: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	margin-bottom: 47px;
	padding-top: 91px;
}

.tour-page-banner .banner-background {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: linear-gradient(rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.3)),
		url('../images/d4eaf544b74f96fec1cb58ff39131e31c8f2a587.jpg') center/cover no-repeat;
	border-radius: 0;
	z-index: 1;
}

.tour-page-banner .banner-content {
	position: relative;
	z-index: 2;
	width: 100%;
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 105px;
	color: var(--white);
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	padding-top: 134px;
}

.banner-title-section {
	position: absolute;
	left: 105px;
	bottom: 120px;
}

.banner-title-group {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.tour-page-banner .page-title {
	font-weight: 500;
	font-size: 35px;
	line-height: 1.6em;
	letter-spacing: 0.02em;
	margin: 0;
	color: var(--white);
}

.tour-page-banner .page-subtitle {
	font-weight: 500;
	font-size: 14.5px;
	line-height: 2em;
	letter-spacing: 0.05em;
	color: var(--white);
	margin: 0;
}

.user-icon-banner {
	position: absolute;
	right: 149px;
	top: 43px;
	width: 32px;
	height: 32px;
}

/* Tour Page Content */
.tour-page-content {
	padding: 60px 0;
	background-color: var(--bg-color);
}

/* ============================================
   旅行ツアー 详情页 页面样式
   ============================================ */

/* 详情页 Banner */
.tour-detail-banner {
	position: relative;
	width: 100%;
	height: 581px;
	margin-top: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	margin-bottom: 47px;
	padding-top: 91px;
}

.tour-detail-banner .banner-background {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: linear-gradient(rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.3)),
		url('../images/d4eaf544b74f96fec1cb58ff39131e31c8f2a587.jpg') center/cover no-repeat;
	border-radius: 0;
	z-index: 1;
}

.tour-detail-banner .banner-content {
	position: relative;
	z-index: 2;
	width: 100%;
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 105px;
	color: var(--white);
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	padding-top: 134px;
	padding-bottom: 40px;
}

.tour-detail-main {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
}

.tour-detail-text {
	max-width: 650px;
}

.tour-detail-label {
	font-weight: 400;
	font-size: 14px;
	line-height: 2.07em;
	letter-spacing: 0.05em;
	margin: 0 0 4px;
}

.tour-detail-title {
	font-weight: 500;
	font-size: 35px;
	line-height: 1.6em;
	letter-spacing: 0.02em;
	margin: 0 0 10px;
}

.tour-detail-meta {
	display: flex;
	gap: 20px;
	font-weight: 400;
	font-size: 16px;
	line-height: 1.5em;
}

.tour-detail-price-block {
	text-align: right;
}

.tour-detail-price-row {
	display: flex;
	align-items: baseline;
	justify-content: flex-end;
	gap: 6px;
}

.tour-detail-price {
	font-weight: 700;
	font-size: 32px;
	line-height: 1.5em;
}

.tour-detail-price-unit {
	font-weight: 500;
	font-size: 14px;
	line-height: 1.8em;
}

.tour-detail-duration {
	margin-top: 8px;
	font-weight: 400;
	font-size: 14px;
	line-height: 1.5em;
}

.tour-detail-breadcrumb {
	margin-top: 40px;
	font-weight: 400;
	font-size: 12px;
	line-height: 1.5em;
	letter-spacing: 0.125em;
}

/* 详情页主体布局 */
.tour-detail-page-content {
	padding: 25px 0 60px;
	background-color: var(--bg-color);
}

.tour-detail-page-content .container {
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 50px;
}

.tour-detail-layout {
	display: flex;
	gap: 16px;
	/* align-items: flex-start; */
	margin-bottom: 60px;
}

/* 中间区域：ツアー詳細及以下部分 */
.tour-detail-center {
	width: 100%;
	background-color: #E0DACF;
	padding: 53px 0;
}

.tour-detail-section-title {
	font-weight: 600;
	font-size: 32px;
	letter-spacing: 0.022em;
	color: #000000;
	margin: 0 0 16px;
}

/* 左侧：ツアー概要 - 浅米色圆角框 */
.tour-detail-left{
	width: calc((100% - 16px)/2);
	background-color: #F0EEEB;
}
.tour-detail-intro-box {
	border-radius: 10px;
	padding: 20px;
	margin-bottom: 0;
}
.lyxq{
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
}
.lyxq1{
	font-weight: 500;
	font-size: 12px;
	line-height: 29.96px;
	color: #000000;
}
.lyxq1 span{
	font-size: 20px;
}
.jtxq1{
	display: flex;
	align-items: center;
	font-weight: 500;
	font-size: 14px;
	color: #6E6E6E;
}
.jtxq1 img{
	margin: 0 6px;
}
.jtxq1 span{
	font-size: 20px;
	color: #000000;
}
.jtxq2{
	display: flex;
	align-items: center;
	font-weight: 600;
	font-size: 32px;
	line-height: 29.34px;
	color: #000000;
}
.jtxq2 span{
	margin-left: 10px;
	display: flex;
	align-items: center;
	font-weight: 500;
	font-size: 14px;
	line-height: 21px;
	color: #6E6E6E;
}
.jtxq2 span:first-child{
    margin-left: 36px;
}
.tour-detail-intro-text {
	font-weight: 500;
	font-size: 14px;
	line-height: 1.8em;
	letter-spacing: 0.05em;
	color: var(--text-dark);
	margin: 0;
}

/* 图片展示区域 */
.tour-detail-image-section {
	margin-top: 40px;
	margin-bottom: 60px;
	width: 100%;
	padding-left: 330px;
}

.tour-detail-image-container {
	position: relative;
	width: 100%;
}

.tour-detail-carousel-wrapper {
	position: relative;
	width: 100%;
	height: 500px;
	overflow: hidden;
	border-radius: 10px;
}

.tour-detail-carousel {
	position: relative;
	width: 100%;
	height: 100%;
}

.tour-detail-carousel-item {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	opacity: 0;
	transition: opacity 0.6s ease-in-out;
	z-index: 1;
}

.tour-detail-carousel-item.active {
	opacity: 1;
	z-index: 2;
}

.tour-detail-large-image {
	width: 100%;
	height: 100%;
	border-radius: 10px;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}

.tour-detail-image-nav {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-top: 20px;
	padding: 0 20px;
}

.tour-detail-image-dots {
	display: flex;
	gap: 8px;
	align-items: center;
}

.tour-detail-dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background-color: #D3D3D3;
	cursor: pointer;
	transition: background-color 0.3s ease;
	display: inline-block;
}

.tour-detail-dot:hover {
	background-color: #A0A0A0;
}

.tour-detail-dot.active {
	background-color: #7B7B7B;
}

.tour-detail-image-arrows {
	display: flex;
	gap: 10px;
	align-items: center;
}

.tour-detail-arrow {
	background: none;
	border: none;
	cursor: pointer;
	padding: 5px;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: opacity 0.3s ease;
}

.tour-detail-arrow:hover {
	opacity: 0.7;
}

.tour-detail-itinerary {
	margin-bottom: 40px;
}



.tour-detail-timeline-item {
	display: flex;
	align-items: flex-start;
	padding: 25px 0;
	border-bottom: 1px solid #272727;
}

.tour-detail-time {
	width: 300px;
	font-weight: 400;
	font-size: 16px;
	line-height: 1.8em;
	letter-spacing: 0.056em;
	color: #000000;
}

.tour-detail-event {
	flex: 1;
	font-weight: 400;
	font-size: 16px;
	line-height: 1.8em;
	letter-spacing: 0.056em;
	color: #000000;
}
.tour-detail-event img{
	width: 100%;
	width: 100%;
	/* max-width: 965px; */
	/* height: 465px; */
	max-width: 365px;
	height: 219px;
	border-radius: 10px;
}
.tour-detail-include-section,
.tour-detail-notes-section {
	margin-bottom: 40px;
}

.tour-detail-include-text,
.tour-detail-notes-text {
	font-weight: 600;
	font-size: 14px;
	line-height: 2.07em;
	letter-spacing: 0.052em;
	color: var(--text-dark);
	margin: 0;
}

/* 右侧预订侧栏 */
.tour-detail-sidebar {
	width: calc((100% - 16px)/2);
}

.tour-detail-sidebar-inner {
	background-color: #FFFFFF;
	border-radius: 10px;
	padding: 35px 40px;
	box-shadow: 0px 4px 20px rgba(0, 0, 0, 0.1);
	color: var(--text-dark);
}

.tour-detail-sidebar-title {
	font-weight: 500;
	font-size: 32px;
	line-height: 1.2em;
	color: #1A1918;
}

.tour-detail-sidebar-info {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 24px;
	flex-wrap: wrap;
	font-size: 14px;
	line-height: 1.5em;
	color: var(--text-dark);
}

.tour-detail-info-item {
	font-weight: 400;
}

.tour-detail-info-icon {
	font-size: 16px;
}

.tour-detail-info-price {
	font-weight: 600;
	font-size: 16px;
	color: var(--text-dark);
	margin-left: auto;
}

.tour-detail-form-group {
	margin-top: 16px;
	width: calc((100% - 24px)/2);
}

.tour-detail-form-label {
	display: block;
	font-family: 'Open Sans', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	font-weight: 700;
	font-size: 15px;
	line-height: 1.5em;
	margin-bottom: 6px;
}
.tour-detail-form-label span{
	color: #FF0000;
}
.tour-detail-input {
	border-radius: 10px;
	background-color: #FFFFFF;
	display: flex;
	align-items: center;
	position: relative;
}
.tour-detail-input input{
	padding: 12px 16px;
	min-height: 49px;
	width: 100%;
	border: 1px solid #DEE0EA;
	border-radius: 10px;
	outline: none;
}
.datepicker-input{
    text-align: center;
    background: url("/public/static/images/dpicon.png") no-repeat;
    background-position: 16px center;
    background-size: 18px auto;
}
.tour-detail-input select{
	padding: 12px 16px;
	min-height: 49px;
	width: 100%;
	border: 1px solid #DEE0EA;
	border-radius: 10px;
	outline: none;
}
.lyxq2{
	margin-top: 30px;
	font-size: 14px;
	color: #2F2F2F;
	padding-left: 96px;
}
.lyxq2 a{
	color: #2F2F2F;
}
.lyxq2a{
	font-size: 14px;
	color: #2F2F2F;
	padding-left: 96px;
}
.lyxq2a a{
	color: #2F2F2F;
}
.lyxq3{
	margin-top: 18px;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.tour-detail-calendar-icon {
	position: absolute;
	left: 17px;
	top: 50%;
	transform: translateY(-50%);
}

.tour-detail-dropdown-icon {
	margin-left: auto;
}

.tour-detail-input-text {
	font-weight: 600;
	font-size: 14px;
	line-height: 1.2em;
	color: rgba(33, 37, 41, 0.75);
	flex: 1;
}

.tour-detail-button {
	border-radius: 10px;
	padding: 10px 16px;
	border: 1px solid #1E1E1E;
	font-weight: 700;
	font-size: 20px;
	line-height: 1.5em;
	cursor: pointer;
	width: calc((100% - 24px)/2);
}

.tour-detail-button.primary {
	background-color: #1E1E1E;
	color: #FFFFFF;
	text-decoration: none;
	text-align: center;
}

.tour-detail-button.secondary {
	background-color: #FFFFFF;
	color: #1E1E1E;
	border: 1px solid #1E1E1E;
	margin-top: 0;
	text-decoration: none;
	text-align: center;
}
.artic_tc{
    display: none;
    position: fixed;
    left: 50%;
    top: 50%;
    z-index: 1003;
    width: 80%;
    transform: translate(-50%,-50%);
    max-width: 366px;
    background-color: #FFFFFF;
    border-radius: 10px;
    padding: 30px 36px;
}
.artic_tc1{
    font-weight: 500;
    font-size: 14px;
    line-height: 22.5px;
    text-align: center;
    color: #000000;
}
.artic_tc2{
    margin-top: 30px;
    border: 1px solid #000000;
    padding: 5px 10px;
    background-color: #F6F6F6;
    font-weight: 500;
    font-size: 12px;
    line-height: 20px;
    color: #1A1918;
    height: 270px;
    overflow-y: scroll;
}
.artic_tc3{
    margin-top: 30px;
}
.artic_tc3 button{
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 114px;
    height: 32px;
    background-color: #000000;
    text-decoration: none;
    font-weight: 700;
    font-size: 14px;
    line-height: 20px;
    color: #FFFFFF;
}

@media (max-width: 1024px) {
	.tour-detail-page-content .container {
		padding: 0 40px;
	}
	.datepicker-input {
	    background-position: 5px center;
	    background-size: 16px auto;
	}
	.tour-detail-event img{
		height: auto;
	}
	.tour-detail-layout {
		/* grid-template-columns: 1fr;
		gap: 40px; */
		display: block;
	}
	.tour-detail-left{
		width: 100%;
	}
	.tour-detail-sidebar {
		width: 100%;
		margin-top: 20px;
	}
	.tour-detail-sidebar-inner{
		padding: 16px 16px 40px;
	}
	.lyxq{
		flex-wrap: wrap;
	}
	.lyxq3{
		display: block;
		text-align: center;
	}
	.tour-detail-button{
		width: 100%;
		font-size: 14px;
	}
	.tour-detail-form-group{
		/* width: 100%; */
	}
	.tour-detail-center {
		max-width: 100%;
		padding: 20px 0;
	}
	.tour-detail-image-section {
		padding-left: 0;
	}
	.tour-detail-button.primary{
		margin-top: 16px;
	}
	.tour-detail-section-title{
		font-size: 20px;
		margin-bottom: 0;
	}
	.tour-detail-timeline-item{
		padding: 16px 0;
		display: block;
	}
	.tour-detail-time{
		font-size: 16px;
	}
	.tour-detail-event{
		font-size: 16px;
	}
	.tour-detail-page-content{
		padding-bottom: 30px;
	}
	.jtxq2{
		display: block;
		font-size: 20px;
	}
	.lyxq2{
	    padding-left: 0;
	}
	.lyxq2a{
	    padding-left: 0;
	}
}

@media (max-width: 768px) {
	.tour-detail-banner {
		height: 400px;
	}

	.tour-detail-banner .banner-content {
		padding: 0 20px 40px;
	}

	.tour-detail-title {
		font-size: 28px;
	}

	.tour-detail-page-content .container {
		padding: 0 20px;
	}

	.tour-detail-carousel-wrapper {
		height: 300px;
	}

	.tour-detail-center {
		max-width: 100%;
		padding: 20px 0;
	}

	.tour-detail-timeline {
		padding: 0;
	}

	.tour-detail-timeline-item {
		grid-template-columns: 1fr;
		gap: 8px;
	}

	.tour-detail-sidebar-info {
		font-size: 12px;
	}

	.tour-detail-sidebar-title {
		font-size: 24px;
	}
}

.tour-description-section {
	padding: 0 100px;
	margin-bottom: 40px;
}

.tour-description-section .description-text {
	font-weight: 400;
	font-size: 14px;
	line-height: 2.07em;
	text-align: justify;
	color: var(--text-dark);
	margin: 0;
}

.tour-layout {
	display: grid;
	grid-template-columns: 300px 1fr;
	gap: 40px;
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 100px;
}

/* Tour Sidebar (复用 about-sidebar 样式，可单独定义) */
.tour-sidebar {
	border-radius: 10px;
	transition: all 0.3s ease;
	height: fit-content;
	min-width: 300px;
}

.tour-sidebar.collapsed {
	min-width: 60px;
	width: 60px;
}

.tour-sidebar .sidebar-header,
.tour-sidebar .sidebar-content,
.tour-sidebar .sidebar-nav,
.tour-sidebar .sidebar-filters {
	/* 复用 about-sidebar 样式 */
}

.tour-sidebar.collapsed .sidebar-content {
	max-height: 0;
	padding: 0;
	opacity: 0;
	overflow: hidden;
}

.tour-sidebar:not(.collapsed) .sidebar-toggle-btn {
	transform: rotate(180deg);
}

.tour-sidebar.collapsed .sidebar-toggle-btn {
	transform: rotate(0deg);
}

/* Tour Main Content */
.tour-main-content {
	background-color: transparent;
}

.tour-main-content .section-heading {
	font-weight: 500;
	font-size: 32px;
	line-height: 1.75em;
	letter-spacing: 0.023em;
	color: var(--text-dark);
	margin-bottom: 40px;
}

.tour-main-content .tour-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 12px;
	margin-bottom: 60px;
}

.inabout{
	margin-top: 46px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-direction: row-reverse;
}
.inabout1{
	width: 380px;
	margin-left: 36px;
}
.inabout2{
	font-size: 0;
	text-align: center;
}
.inabout2 img{
	margin: 0 auto;
}
.inabout3{
	display: none;
	font-weight: 500;
	font-size: 0;
	line-height: 0;
	letter-spacing: 0.98px;
	color: #2A2C2C;
}
.inabout4{
	flex: 1;
}
.inabout5{
	font-weight: 500;
	font-size: 32px;
	line-height: 56px;
	letter-spacing: 0.72px;
	color: #3E4048;
}
.inabout6{
	margin-top: 30px;
	font-size: 14px;
	line-height: 29px;
	text-align: justify;
	color: #3E4048;
}
.abima{
	margin: 96px auto 0;
	max-width: 1440px;
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
}
.abima1{
	width: 100%;
	max-width: 895px;
	margin-right: 72px;
}
.abima2{
	flex: 1;
	margin-bottom: -94px;
}

/* 响应式设计 - Tour Page */
@media (max-width: 1024px) {
	.tour-layout {
		grid-template-columns: 1fr;
		gap: 30px;
		padding: 0;
	}

	.tour-sidebar {
		order: 2;
	}

	.tour-main-content {
		order: 3;
	}
    .breadcrumb-nav {
		padding: 0;
	    display: none;
	}
	.tour-description-section {
	    display: none;
		padding: 0;
		margin-bottom: 20px;
	}

	.tour-main-content .tour-grid {
		grid-template-columns: 1fr;
	}
    .pagination{
        gap: 16px;
    }
	.tour-sidebar.collapsed {
		width: 100%;
	}

	.banner-title-section {
		flex-direction: column;
		align-items: flex-start;
		gap: 20px;
	}
	.inabout{
		margin-top: 30px;
		display: block;
	}
	.inabout1{
		width: 100%;
		margin: 0;
	}
	.inabout3{
		font-size: 20px;
		text-align: center;
	}
	.about-page-content{
	    padding-bottom: 0;
	}
	.inabout4{
		width: 100%;
	}
	.inabout5{
		font-size: 20px;
	}
	.abima{
		margin-top: 30px;
		display: block;
	}
	.abima2{
		margin: 20px 0 0;
	}
	.about-vision-section{
		margin: 30px 0;
	}
	.abimg{
		margin-top: 30px;
	}
	.abimg .swiper {
		padding: 0 10%;
	}

}

@media (max-width: 768px) {
	.tour-page-banner {
		height: 400px;
	}

	.tour-page-banner .banner-content {
		padding: 20px;
		padding-top: 100px;
		padding-bottom: 50px;
	}

	.tour-page-banner .page-title {
		font-size: 28px;
	}

	.tour-main-content .tour-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.tour-layout {
		padding: 0;
	}
	.inabout2 img{
	    width: 100px;
	}
	
	
	
}

/* ============================================
   交通手配 页面样式
   ============================================ */

/* Transportation Page Banner */
.transportation-page-banner {
	position: relative;
	width: 100%;
	height: 581px;
	margin-top: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	margin-bottom: 47px;
}

.transportation-page-banner .banner-background {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: linear-gradient(rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.3)),
		url('../images/c8f692f575b1eface05b46093f5512bde6fcb767.jpg') center/cover no-repeat;
	border-radius: 0;
	z-index: 1;
}

.transportation-page-banner .banner-content {
	position: relative;
	z-index: 2;
	width: 100%;
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 105px;
	padding-top: 134px;
	color: var(--white);
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
}

.transportation-page-banner .banner-title-section {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
}

.transportation-page-banner .banner-title-group {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
}

.transportation-page-banner .page-title {
	font-weight: 500;
	font-size: 35px;
	line-height: 1.6em;
	letter-spacing: 0.021em;
	color: var(--white);
	margin: 0 0 10px 0;
}

.transportation-page-banner .page-subtitle {
	font-weight: 500;
	font-size: 14.5px;
	line-height: 2em;
	letter-spacing: 0.05em;
	color: var(--white);
	margin: 0;
}

.transportation-page-banner .user-icon-banner {
	width: 32px;
	height: 32px;
	cursor: pointer;
}

/* Transportation Page Content */
.transportation-page-content {
	padding: 0;
	background-color: var(--bg-color);
	min-height: calc(100vh - 91px);
}

.transportation-page-content .container {
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 105px;
}

/* Breadcrumb Navigation */
.transportation-page-content .breadcrumb-nav {
	display: flex;
	align-items: center;
	gap: 5px;
	margin-bottom: 79px;
	padding-top: 0;
}

.transportation-page-content .breadcrumb-link {
	font-weight: 400;
	font-size: 12px;
	line-height: 1.5em;
	letter-spacing: 0.125em;
	color: #0B0C0D;
	text-decoration: none;
}

.transportation-page-content .breadcrumb-separator {
	font-weight: 400;
	font-size: 12px;
	line-height: 1.5em;
	letter-spacing: 0.125em;
	color: var(--text-dark);
}

.transportation-page-content .breadcrumb-current {
	font-weight: 400;
	font-size: 12px;
	line-height: 1.5em;
	letter-spacing: 0.125em;
	color: var(--text-dark);
}

/* Main Content Layout */
.transportation-main-layout {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 80px;
	align-items: flex-start;
	margin-bottom: 60px;
}

/* Left: Title Section */
.transportation-title-section {
	flex-shrink: 0;
}

.transportation-main-title {
	font-weight: 500;
	font-size: 32px;
	line-height: 1.75em;
	letter-spacing: 0.023em;
	color: var(--text-dark);
	margin: 0;
	white-space: nowrap;
}

/* Right: Cards Section */
.transportation-cards-section {
	flex: 1;
	min-width: 0;
}

/* Transportation Cards Grid */
.transportation-cards-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 12px;
	justify-content: start;
}

/* Transportation Card */
.transportation-card {
	/*width: 407px;*/
	background-color: var(--white);
	border-radius: 10px;
	overflow: hidden;
	box-shadow: 0px 0px 30px 0px rgba(0, 0, 0, 0.1);
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.transportation-card:hover {
	transform: translateY(-5px);
	box-shadow: 0px 5px 40px 0px rgba(0, 0, 0, 0.15);
}

.transportation-card .card-image-section {
	position: relative;
	width: 100%;
	border-radius: 10px 10px 0 0;
	font-size: 0;
	height: 170px;
	overflow: hidden;
}
.transportation-card .card-image-section img{
	width: 100%;
}
.transportation-card .card-label {
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	font-weight: 400;
	font-size: 14px;
	line-height: 40px;
	color: #ffffff;
	background-color: rgba(0, 0, 0, 0.5);
	text-align: center;
}
.jtcart{
	padding: 14px;
}
.transportation-card .card-content {
	/* padding: 30px 6px 0; */
	background-color: var(--white);
	border-radius: 0 0 10px 10px;
}

.transportation-card .card-title {
	font-weight: 700;
	font-size: 16px;
	line-height: 20px;
	height: 40px;
	overflow : hidden;
	text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	color: var(--black);
	margin: 0 0 2px 0;
}

.transportation-card .card-location {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 8px;
}

.transportation-card .location-icon {
	font-size: 15px;
	color: #5E902D;
}

.transportation-card .location-text {
	font-weight: 500;
	font-size: 12px;
	line-height: 1.5em;
	color: #6E6E6E;
}

.transportation-card .card-divider {
	width: 100%;
	height: 1px;
	background-color: #E4E4E4;
	margin: 19px 0;
}

.transportation-card .card-description {
	font-weight: 500;
	font-size: 12px;
	line-height: 1.5em;
	color: #6E6E6E;
	overflow : hidden;
	text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	margin: 0 0 11px 0;
}

.transportation-card .card-footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.transportation-card .card-price {
	font-weight: 700;
	font-size: 16px;
	line-height: 1.7em;
	color: var(--black);
	text-align: right;
}

.transportation-card .card-vehicle-type {
	display: none;
	align-items: center;
	gap: 9px;
	padding: 10px 20px;
	border: 1px solid #DFDFDF;
	border-radius: 0;
	font-weight: 500;
	font-size: 14px;
	line-height: 1.5em;
	color: #6E6E6E;
}
.xstc{
	font-size: 0;
}
.xstc_tc{
	display: none;
	position: fixed;
	left: 0;
	top: 0;
	z-index: 1005;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.3);
}
.xstc_tc1{
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%,-50%);
	background-color: #FFFFFF;
	width: 80%;
	max-width: 654px;
	height: 261px;
	border-radius: 10px;
	padding: 32px 25px 20px;
}
.xstc_close{
	position: absolute;
	font-size: 0;
	right: 4px;
	top: 4px;
}
.xstc_tc2{
	height: calc(100% - 40px);
	overflow-y: scroll;
	font-weight: 500;
	font-size: 11.74px;
	line-height: 17.6px;
	color: #6E6E6E;
}
.xstc_tc3{
	margin-top: 16px;
}
.xstc_tc3 a{
	display: block;
	width: 115px;
	height: 24px;
	background-color: #1E1E1E;
	font-weight: 700;
	font-style: Bold;
	font-size: 10.27px;
	line-height: 24px;
	color: #FFFFFF;
	text-align: center;
	text-decoration: underline;
}
.transportation-card .vehicle-icon {
	font-size: 15px;
}

.transportation-card .card-button {
	display: inline-block;
	/* padding: 6px 7px;
	background-color: #1E1E1E; */
	color: var(--white);
	font-weight: 700;
	font-size: 12px;
	line-height: 1em;
	text-decoration: none;
	border-radius: 2px;
	text-align: center;
	transition: background-color 0.3s ease;
	/* margin-right: 25px; */
}

.transportation-card .card-button:hover {
	background-color: #333;
}
.card-footer .card-button{
	padding: 6px 7px !important;
	background-color: #1E1E1E !important;
}
.transportation-page-layout {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0;
	max-width: 1440px;
	margin: 0 auto;
	padding: 0;
	align-items: stretch;
}

/* Transportation Slider Section */
.transportation-slider-section {
	width: 100%;
}

.transportation-page-layout .transportation-slider {
	position: relative;
	width: 100%;
	height: 445.78px;
	border-radius: 11.25px 0 0 11.25px;
	overflow: hidden;
}

.transportation-page-layout .slider-wrapper {
	position: relative;
	width: 100%;
	height: 100%;
}

.transportation-page-layout .slider-item {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	opacity: 0;
	transition: opacity 0.5s ease;
}

.transportation-page-layout .slider-item.active {
	opacity: 1;
	z-index: 1;
}

.transportation-page-layout .slider-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.slider-controls {
	position: absolute;
	bottom: 20px;
	right: 20px;
	display: flex;
	gap: 10px;
	z-index: 2;
}

.slider-prev,
.slider-next {
	width: 40px;
	height: 40px;
	background-color: rgba(0, 0, 0, 0.5);
	border: none;
	border-radius: 50%;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background-color 0.3s ease;
}

.slider-prev:hover,
.slider-next:hover {
	background-color: rgba(0, 0, 0, 0.7);
}

/* Transportation Content Section */
.transportation-content-section {
	padding: 60px 72px;
	background-color: var(--bg-color);
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	min-height: 445.78px;
}

.transportation-content-section .section-header {
	margin-bottom: 30px;
}

.transportation-content-section .section-title-large {
	font-weight: 500;
	font-size: 35px;
	line-height: 1.6em;
	letter-spacing: 0.02em;
	color: var(--text-dark);
	margin: 0 0 10px 0;
}

.transportation-content-section .section-subtitle-large {
	font-weight: 500;
	font-size: 14.5px;
	line-height: 2em;
	letter-spacing: 0.05em;
	color: var(--text-dark);
	margin: 0;
}

/* ============================================
   ご利用ガイド 页面样式
   ============================================ */

/* Guide Page Banner */
.guide-page-banner {
	position: relative;
	width: 100%;
	height: 581px;
	margin-top: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	margin-bottom: 47px;
	padding-top: 91px;
}

.guide-page-banner .banner-background {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: linear-gradient(rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.3)),
		url('../images/e59fd266fbece397d0805a9a64754f922b8b2c8a.jpg') center/cover no-repeat;
	border-radius: 0;
	z-index: 1;
}

.guide-page-banner .banner-content {
	position: relative;
	z-index: 2;
	width: 100%;
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 105px;
	color: var(--white);
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	padding-top: 134px;
	padding-bottom: 40px;
}

.guide-page-banner .banner-title-section {
	position: absolute;
	left: 105px;
	bottom: 120px;
}

.guide-page-banner .page-title {
	font-weight: 500;
	font-size: 35px;
	line-height: 1.6em;
	letter-spacing: 0.02em;
	margin: 0;
	color: var(--white);
}

.guide-page-banner .page-subtitle {
	font-weight: 500;
	font-size: 14.5px;
	line-height: 2em;
	letter-spacing: 0.05em;
	color: var(--white);
	margin: 0;
}

.guide-page-banner .user-icon-banner {
	position: absolute;
	right: 149px;
	top: 43px;
	width: 32px;
	height: 32px;
}

/* Guide Page Content */
.guide-page-content {
	padding: 60px 0;
	background-color: var(--bg-color);
}

.guide-page-content .container {
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 105px;
}

.guide-layout {
	display: grid;
	grid-template-columns: 301px 1fr;
	gap: 80px;
	margin-top: 40px;
	align-items: flex-start;
}

/* Guide Sidebar */
.guide-sidebar {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.guide-menu-item {
	background-color: #F6F2EC;
	border-radius: 0;
	padding: 12px 20px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	cursor: pointer;
	transition: all 0.3s ease;
}

.guide-menu-item:hover {
	background-color: #EDE5D8;
}

.guide-menu-item.active {
	background-color: #F6F2EC;
}

.guide-menu-text {
	font-weight: 500;
	font-size: 16px;
	line-height: 1.81em;
	letter-spacing: 0.045em;
	color: #000000;
	flex: 1;
}

.guide-menu-item.active .guide-menu-text {
	color: #A22324;
}

.guide-menu-chevron {
	flex-shrink: 0;
	margin-left: 10px;
}

/* Guide Content */
.guide-content {
	position: relative;
	min-height: 400px;
}

.guide-content-item {
	display: none;
	animation: fadeIn 0.3s ease-in-out;
}

.guide-content-item.active {
	display: block;
}

@keyframes fadeIn {
	from {
		opacity: 0;
		transform: translateY(10px);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.guide-content-title {
	font-weight: 500;
	font-size: 32px;
	line-height: 1.81em;
	letter-spacing: 0.045em;
	color: #000000;
	margin: 0 0 30px;
}

.guide-content-body {
	font-weight: 500;
	font-size: 14px;
	line-height: 2.07em;
	letter-spacing: 0.052em;
	color: #000000;
}

.guide-content-body p {
	margin: 0 0 20px;
}

.guide-step {
	margin-bottom: 30px;
}

.guide-step-title {
	font-weight: 500;
	font-size: 14px;
	line-height: 2.07em;
	letter-spacing: 0.052em;
	color: #000000;
	margin: 0 0 10px;
}

.guide-step-text {
	font-weight: 500;
	font-size: 14px;
	line-height: 2.07em;
	letter-spacing: 0.052em;
	color: #000000;
	margin: 0;
}

/* Responsive Design - Guide Page */
@media (max-width: 1024px) {
	.guide-page-content .container {
		padding: 0 40px;
	}

	.guide-layout {
		grid-template-columns: 1fr;
		gap: 40px;
	}

	.guide-sidebar {
		order: 2;
	}

	.guide-content {
		order: 1;
	}
	.guide-content-title{
		font-size: 20px;
	}
	.transportation-card .card-image-section{
		height: 100px;
	}
	.jtcart{
		padding: 10px;
	}
	.transportation-card .card-title{
		font-size: 14px;
	}
	.transportation-card .card-description{
		font-size: 12px;
		margin-bottom: 10px;
	}
	.tour-location {
		gap: 2px;
		font-size: 12px;
	}
	.tour-card-meta{
		gap: 5px;
	}
	.transportation-card .card-button {
		padding: 0;
		font-size: 12px;
		margin-right: 0;
	}
	.card-footer .card-button{
		padding: 3px 3px !important;
	}
	.transportation-card .card-price{
		font-size: 12px;
		text-align: left;
	}
	.transportation-card .card-footer{
		/* display: block; */
		flex-wrap: wrap;
		justify-content: center;
	}
	.card-price{
		width: calc(100% - 20px);
	}










}

@media (max-width: 768px) {
	.guide-page-banner {
		height: 400px;
	}

	.guide-page-banner .banner-content {
		padding: 0 20px 40px;
	}

	.guide-page-content .container {
		padding: 0 20px;
	}

	.guide-layout {
		gap: 30px;
	}

	.guide-menu-item {
		padding: 10px 16px;
	}

	.guide-menu-text {
		font-size: 14px;
	}
}

/* ============================================
   お知らせ 页面样式
   ============================================ */

/* News Page Banner */
.news-page-banner {
	position: relative;
	width: 100%;
	height: 581px;
	margin-top: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	margin-bottom: 47px;
	padding-top: 91px;
}

.news-page-banner .banner-background {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: linear-gradient(rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.3)),
		url('../images/f5b9d7a957e1c82d041f776a0c40382a58e7a17a.jpg') center/cover no-repeat;
	border-radius: 30px;
	z-index: 1;
	margin: 25px;
	width: calc(100% - 50px);
	height: calc(100% - 50px);
}

.news-page-banner .banner-content {
	position: relative;
	z-index: 2;
	width: 100%;
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 105px;
	color: var(--white);
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	padding-top: 134px;
	padding-bottom: 40px;
}

.news-page-banner .banner-title-section {
	position: absolute;
	left: 105px;
	bottom: 120px;
}

.news-page-banner .page-title {
	font-weight: 500;
	font-size: 35px;
	line-height: 1.6em;
	letter-spacing: 0.02em;
	margin: 0;
	color: var(--white);
}

.news-page-banner .page-subtitle {
	font-weight: 500;
	font-size: 14.5px;
	line-height: 2em;
	letter-spacing: 0.05em;
	color: var(--white);
	margin: 0;
}

.news-page-banner .user-icon-banner {
	position: absolute;
	right: 149px;
	top: 43px;
	width: 32px;
	height: 32px;
}

/* News Page Content */
.news-page-content {
	padding: 60px 0;
	background-color: var(--bg-color);
}

.news-page-content .container {
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 105px;
}

/* News Layout */
.news-layout {
	display: grid;
	grid-template-columns: 301px 1fr;
	gap: 80px;
	margin-top: 40px;
	align-items: flex-start;
}

/* News Sidebar (Left) */
.news-sidebar {
	display: flex;
	flex-direction: column;
	gap: 0;
}

.news-filter-btn {
	background: none;
	border: none;
	padding: 20px 0;
	font-weight: 500;
	font-size: 16px;
	line-height: 1.81em;
	letter-spacing: 0.045em;
	color: #000000;
	cursor: pointer;
	transition: all 0.3s ease;
	text-align: left;
	width: 100%;
}

.news-filter-btn:hover {
	background-color: #EDE5D8;
}

.news-filter-btn.active {
	color: #A22324;
}

/* News Content (Right) */
.news-content {
	width: 100%;
	max-width: 870px;
}

.news-item {
	margin-bottom: 0;
	border-bottom: 1px solid #C1C1C1;
	cursor: pointer;
	transition: all 0.3s ease;
	background-color: transparent;
	border-radius: 0;
	padding: 10px 0;
}
.news-content .news-item a{
	text-decoration: none;
}
.news-item:first-child {
	/* background-color: #F6F2EC; */
	/* border-radius: 10px;
	padding: 15px;
	margin-bottom: 0;
	border-bottom: 1px solid #C1C1C1; */
}

.news-item:hover {
	opacity: 0.7;
}

/* .news-item:last-child {
	border-bottom: none;
} */

/* .news-item-inner {
	display: flex;
	flex-direction: column;
	gap: 0;
} */

/* .news-item:first-child .news-item-inner {
	padding: 0;
} */

.news-item-date {
	font-weight: 500;
	font-size: 14px;
	line-height: 2.07em;
	letter-spacing: 0.052em;
	color: #6E6E6E;
	margin-bottom: 6px;
}

.news-item-title {
	font-weight: 500;
	font-size: 16px;
	line-height: 1.81em;
	letter-spacing: 0.045em;
	color: #000000;
	margin-bottom: 0;
}

.news-item-divider {
	width: 100%;
	height: 1px;
	background-color: #C1C1C1;
}

/* Responsive Design - News Page */
@media (max-width: 1024px) {
	.news-page-content .container {
		padding: 0 40px;
	}

	.news-layout {
		grid-template-columns: 1fr;
		gap: 40px;
	}

	.news-sidebar {
		order: 2;
		flex-direction: row;
	}

	.news-content {
		order: 3;
	}

	.news-filter-btn {
		padding: 5px;
		font-size: 14px;
	}
}

@media (max-width: 768px) {
    
    .news-page-content{
        padding: 10px 0 30px;
    }
    .news-layout{
        margin-top: 20px;
    }
	.news-page-banner {
		height: 400px;
	}

	.news-page-banner .banner-content {
		padding: 0 20px 40px;
	}

	.news-page-content .container {
		padding: 0 20px;
	}

	.news-layout {
		gap: 30px;
	}

	.news-filter-btn {
		padding: 5px;
		width: auto;
		font-size: 14px;
	}

	.news-item {
		padding: 12px;
	}

	.news-item:first-child {
		padding: 12px;
	}

	.news-item-title {
		font-size: 14px;
	}
}

/* ============================================
   お知らせ-详情页 页面样式
   ============================================ */

/* News Detail Page Banner */
.news-detail-page-banner {
	position: relative;
	width: 100%;
	height: 581px;
	margin-top: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	margin-bottom: 47px;
	padding-top: 91px;
}

.news-detail-page-banner .banner-background {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: linear-gradient(rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.3)),
		url('../images/f5b9d7a957e1c82d041f776a0c40382a58e7a17a.jpg') center/cover no-repeat;
	border-radius: 0;
	z-index: 1;
}

.news-detail-page-banner .banner-content {
	position: relative;
	z-index: 2;
	width: 100%;
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 105px;
	color: var(--white);
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	padding-top: 134px;
	padding-bottom: 40px;
}

.news-detail-page-banner .banner-title-section {
	position: absolute;
	left: 105px;
	bottom: 120px;
}

.news-detail-page-banner .page-title {
	font-weight: 500;
	font-size: 35px;
	line-height: 1.6em;
	letter-spacing: 0.02em;
	margin: 0;
	color: var(--white);
}

.news-detail-page-banner .page-subtitle {
	font-weight: 500;
	font-size: 14.5px;
	line-height: 2em;
	letter-spacing: 0.05em;
	color: var(--white);
	margin: 0;
}

.news-detail-page-banner .user-icon-banner {
	position: absolute;
	right: 149px;
	top: 43px;
	width: 32px;
	height: 32px;
}

/* News Detail Page Content */
.news-detail-page-content {
	padding: 60px 0;
	background-color: var(--bg-color);
}

.news-detail-page-content .container {
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 105px;
}

.news-detail-article {
	margin: 40px auto 0;
}
.wid100 img{
	width: 100%;
	max-width: 100%;
}

.news-detail-title {
	font-weight: 500;
	font-size: 35px;
	line-height: 1.6em;
	letter-spacing: 0.02em;
	color: #000000;
	margin: 0 0 20px;
}

.news-detail-date {
	font-weight: 500;
	font-size: 14.5px;
	line-height: 2em;
	letter-spacing: 0.05em;
	color: #000000;
	margin-bottom: 30px;
}

.news-detail-divider-top {
	width: 100%;
	height: 1px;
	background-color: #C1C1C1;
	margin-bottom: 40px;
}

.news-detail-image {
	width: 100%;
	max-width: 500px;
	margin-bottom: 40px;
	border-radius: 10px;
	overflow: hidden;
}

.news-detail-image img {
	width: 100%;
	height: auto;
	display: block;
	object-fit: cover;
}

.news-detail-content {
	margin-bottom: 60px;
}

.news-detail-content p {
	font-weight: 400;
	font-size: 14px;
	line-height: 2.07em;
	letter-spacing: 0.052em;
	color: #000000;
	margin: 0 0 20px;
	text-align: justify;
}

.news-detail-content p:last-child {
	margin-bottom: 0;
}

/* News Detail Navigation */
.news-detail-navigation {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-top: 40px;
	padding-top: 20px;
	border-top: 1px solid #C0C0C0;
}

.news-nav-link {
	font-weight: 500;
	font-size: 18px;
	line-height: 1.67em;
	color: #1A1918;
	text-decoration: none;
	transition: opacity 0.3s ease;
}

.news-nav-link:hover {
	opacity: 0.7;
}

.news-nav-center {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 20px;
}

.news-nav-divider {
	width: 180px;
	height: 1px;
	background-color: #040404;
}

.news-nav-list {
	font-weight: 500;
	font-size: 20px;
	line-height: 1.2em;
	color: #1A1918;
}

/* Responsive Design - News Detail Page */
@media (max-width: 1024px) {
	.news-detail-page-content .container {
		padding: 0 40px;
	}

	.news-detail-article {
		max-width: 100%;
		margin-top: 20px;
	}
    
	.news-detail-image {
		width: 100% !important;
		max-width: 100%;
	}
	.news-detail-page-content{
	    padding-top: 10px;
	}
	.news-detail-page-content .breadcrumb-nav{
	    display: block !important;
	}
	
	
}

@media (max-width: 768px) {
	.news-detail-page-banner {
		height: 400px;
	}

	.news-detail-page-banner .banner-content {
		padding: 0 20px 40px;
	}

	.news-detail-page-content .container {
		padding: 0 20px;
	}

	.news-detail-title {
		font-size: 20px;
	}

	.news-detail-navigation {
		/* flex-direction: column;
		gap: 20px;
		align-items: flex-start; */
	}
	.news-nav-link{
		font-size: 14px;
	}
	.news-nav-center {
		/* width: 100%;
		align-items: flex-start; */
	}

	.news-nav-divider {
		width: 100%;
	}

	.news-detail-content p {
		font-size: 13px;
	}
}

.transportation-content-section .section-text {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 20px;
}

.transportation-content-section .section-text p {
	font-weight: 400;
	font-size: 14px;
	line-height: 2.07em;
	text-align: left;
	color: var(--text-dark);
	margin: 0;
	width: 100%;
}

/* 响应式设计 - Transportation Page */
@media (max-width: 1024px) {
	.transportation-page-content .container {
		padding: 0 20px;
	}

	.transportation-main-layout {
		grid-template-columns: 1fr;
		gap: 40px;
	}

	.transportation-title-section {
		order: 1;
	}

	.transportation-cards-section {
		order: 2;
	}

	.transportation-main-title {
		white-space: normal;
		margin-bottom: 0;
	}

	.transportation-cards-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 10px;
		justify-items: center;
	}

	.transportation-card {
		width: 100%;
		max-width: 407px;
	}

	.transportation-page-banner {
		height: 400px;
	}

	.transportation-page-banner .banner-content {
		padding: 20px;
		padding-top: 120px;
	}
}

@media (max-width: 768px) {
	.transportation-page-banner {
		height: 300px;
		margin-bottom: 30px;
	}

	.transportation-page-banner .banner-content {
		padding: 15px;
		padding-top: 100px;
		flex-direction: column;
		align-items: flex-start;
		gap: 20px;
	}

	.transportation-page-banner .banner-background {
		top: 0;
		left: 0;
		width: 100%;
		border-radius: 0;
	}

	.transportation-page-banner .page-title {
		font-size: 28px;
	}

	.transportation-page-content .breadcrumb-nav {
		margin-bottom: 40px;
	}

	.transportation-main-layout {
		gap: 30px;
	}

	.transportation-main-title {
		font-size: 24px;
		white-space: normal;
	}

	.transportation-cards-grid {
		gap: 10px;
	}

	.transportation-card {
		max-width: 100%;
	}
}

/* ============================================
   お問い合わせ 页面样式
   ============================================ */

/* Contact Page Banner */
.contact-page-banner {
	position: relative;
	width: 100%;
	height: 581px;
	margin-top: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	margin-bottom: 47px;
	padding-top: 91px;
}

.contact-page-banner .banner-background {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: linear-gradient(rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.3)),
		url('../images/27cd1735653cabb2b8cfd16095f8ee71745343e7.jpg') center/cover no-repeat;
	border-radius: 0;
	z-index: 1;
}

.contact-page-banner .banner-content {
	position: relative;
	z-index: 2;
	width: 100%;
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 105px;
	color: var(--white);
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	padding-top: 134px;
	padding-bottom: 40px;
}

.contact-page-banner .banner-title-section {
	position: absolute;
	left: 105px;
	bottom: 120px;
}

.contact-page-banner .page-title {
	font-weight: 500;
	font-size: 35px;
	line-height: 1.6em;
	letter-spacing: 0.02em;
	margin: 0;
	color: var(--white);
}

.contact-page-banner .page-subtitle {
	font-weight: 500;
	font-size: 14.5px;
	line-height: 2em;
	letter-spacing: 0.05em;
	color: var(--white);
	margin: 0;
}

.contact-page-banner .user-icon-banner {
	position: absolute;
	right: 149px;
	top: 43px;
	width: 32px;
	height: 32px;
}

/* Contact Page Content */
.contact-page-content {
	padding: 60px 0;
	background-color: var(--bg-color);
}

.contact-layout {
	display: grid;
	grid-template-columns: 301px 1fr;
	gap: 80px;
	margin-top: 60px;
}

/* Contact Sidebar */
.contact-sidebar {
	display: flex;
	flex-direction: column;
	position: sticky;
    top: 111px;
    align-self: flex-start;
}

.contact-menu-item {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 12px 21px;
	background-color: #F6F2EC;
	border-radius: 5px;
	cursor: pointer;
	transition: all 0.3s ease;
}
.contact-menu-item a{
	text-decoration: none;
}
.contact-menu-item.active {
	background-color: #F6F2EC;
}

.contact-menu-item.active span {
	color: #A22324;
	font-weight: 500;
	font-size: 16px;
	line-height: 1.8125em;
	letter-spacing: 0.045em;
}

.contact-menu-item:not(.active) span {
	color: #000000;
	font-weight: 500;
	font-size: 16px;
	line-height: 1.8125em;
	letter-spacing: 0.045em;
}

.contact-menu-item:hover {
	background-color: #EDE5D8;
}

/* Contact Form Section */
.contact-form-section {
	max-width: 595px;
}

.contact-description {
	margin-bottom: 25px;
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 20px;
}

.contact-description-text {
	font-weight: 400;
	font-size: 14px;
	line-height: 1.7857em;
	color: #000000;
	margin: 0;
	flex: 1;
}

.contact-required-label {
	display: flex;
	align-items: center;
	gap: 4px;
	font-weight: 400;
	font-size: 7.734px;
	line-height: 2.133em;
	letter-spacing: 0.0646em;
	color: #000000;
	white-space: nowrap;
}

.contact-required-label .required-asterisk {
	color: #BC261A;
	font-size: 16px;
	line-height: 1.16em;
	letter-spacing: 0.025em;
}

/* Contact Form */
.contact-form {
	background-color: transparent;
	border: none;
	border-radius: 0;
	padding: 0;
}

.form-group {
	display: grid;
	grid-template-columns: 135px 1fr;
	gap: 20px;
	margin-bottom: 24px;
	align-items: start;
}

.form-group:last-of-type {
	margin-bottom: 0;
}

.form-label-cell {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 4px;
	padding-top: 4px;
}

.form-input-cell {
	flex: 1;
}

.form-label {
	font-weight: 400;
	font-size: 14px;
	line-height: 1.326em;
	letter-spacing: 0.0286em;
	color: #000000;
	text-align: right;
}

.required-asterisk {
	color: #BC261A;
	font-weight: 400;
	font-size: 16px;
	line-height: 1.16em;
	letter-spacing: 0.025em;
}

.form-input-wrapper {
	position: relative;
}

.form-select {
	width: 100%;
	padding: 0 10px;
	height: 40px;
	border: 1px solid #BFBFBF;
	border-radius: 5px;
	background-color: #FFFFFF;
	font-weight: 400;
	font-size: 14px;
	line-height: 2.125em;
	color: #000000;
	cursor: pointer;
	max-width: 413px;
	outline: none;
}

.select-arrow {
	position: absolute;
	right: 12px;
	top: 50%;
	transform: translateY(-50%);
	pointer-events: none;
}

.form-input,
.form-textarea {
	width: 100%;
	padding: 0 10px;
	height: 40px;
	border: 1px solid #BFBFBF;
	border-radius: 5px;
	background-color: #FFFFFF;
	font-weight: 400;
	font-size: 14px;
	line-height: 1.5em;
	color: #000000;
	font-family: 'Noto Serif JP', serif;
	max-width: 413px;
	outline: none;
}

.form-textarea {
	max-width: 413px;
}


.form-textarea {
	resize: vertical;
	min-height: 200px;
}

.form-input-small {
	width: 128px;
}

.form-input-with-hint {
	display: flex;
	align-items: center;
	gap: 8px;
}

.form-hint {
	font-weight: 400;
	font-size: 12px;
	line-height: 1.5em;
	color: #666666;
	white-space: nowrap;
}

.form-submit-wrapper {
	margin: 40px 0 20px;
	text-align: center;
	grid-column: 1 / -1;
}

.form-submit-btn {
	width: 314px;
	height: 40px;
	background-color: #1E1E1E;
	color: #FFFFFF;
	border: none;
	border-radius: 99px;
	font-weight: 600;
	font-size: 16px;
	line-height: 1.21875em;
	letter-spacing: 0.0625em;
	cursor: pointer;
	transition: background-color 0.3s ease;
}

.form-submit-btn:hover {
	background-color: #3E4048;
}

.form-checkbox-wrapper {
	margin-top: 20px;
	padding-right: 0;
}

.form-checkbox {
	width: 16px;
	height: 16px;
	border: 2px solid #A22324;
	border-radius: 99px;
	appearance: none;
	cursor: pointer;
	position: relative;
	flex-shrink: 0;
}

.form-checkbox:checked {
	background-color: #A22324;
}

.form-checkbox:checked::after {
	content: '';
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 10px;
	height: 7px;
	background-image: url("data:image/svg+xml,%3Csvg width='10' height='7' viewBox='0 0 10 7' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 3.5L3.5 6L9 1' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: center;
}

.form-checkbox-label {
	display: flex;
	align-items: center;
	cursor: pointer;
	color: #333333;
}
.form-checkbox-label a{
	color: #A22324;
}
.checkbox-text {
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 350;
	font-size: 14px;
	line-height: 1.5em;
	color: #A22324;
}

/* Responsive Styles for Contact Page */
@media (max-width: 1024px) {
	.contact-layout {
		grid-template-columns: 250px 1fr;
		gap: 40px;
	}

	.contact-form-section {
		max-width: 100%;
	}
	.contact-page-content{
		padding: 10px 0 30px;
	}
	.contact-layout{
		margin-top: 20px;
	}
}

@media (max-width: 768px) {
	.contact-page-banner {
		height: 400px;
	}

	.contact-page-banner .banner-content {
		padding: 0 20px 40px;
	}

	.contact-layout {
		grid-template-columns: 1fr;
		gap: 30px;
	}

	.contact-sidebar {
		flex-direction: row;
		overflow-x: auto;
		position: relative;
        top: auto;
        align-self: flex-start;
	}

	.contact-menu-item {
		flex-shrink: 0;
		min-width: 200px;
	}

	.contact-description {
		flex-direction: column;
		gap: 10px;
	}

	.form-group {
		grid-template-columns: 1fr;
		gap: 8px;
	}

	.form-label-cell {
		justify-content: flex-start;
	}

	.form-label {
		text-align: left;
	}

	.form-submit-wrapper {
		grid-column: 1;
	}

	.form-checkbox-wrapper {
		grid-column: 1;
		justify-content: flex-start;
	}

	.form-submit-btn {
		width: 100%;
	}

	.form-input-small {
		width: 100%;
	}

	.form-input-with-hint {
		flex-direction: column;
		align-items: flex-start;
	}

	.form-input,
	.form-textarea,
	.form-select {
		max-width: 100%;
	}
}

/* Login Page Styles */
/* Login page uses the same banner style as contact page */

.login-page-content {
	padding: 60px 0;
	background-color: var(--bg-color);
}

.login-page-header {
	max-width: 1000px;
	margin: 0 auto 60px;
	text-align: center;
}

.login-page-title {
	font-weight: 400;
	font-size: 32px;
	line-height: 1.7em;
	letter-spacing: 0.021875em;
	color: #333333;
	margin: 0 0 20px 0;
	font-family: 'Noto Serif JP', serif;
}

.login-page-separator {
	width: 100%;
	height: 1px;
	background-color: #000000;
	margin: 0 auto;
	max-width: 1000px;
}

.login-layout {
	max-width: 1000px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 449px 1fr;
	gap: 67px;
	align-items: start;
}

.login-section-title {
	font-weight: 700;
	font-size: 14px;
	line-height: 2.2857142857142856em;
	letter-spacing: 0.05em;
	color: #333333;
	margin: 0 0 10px 0;
}

.login-form {
	margin-top: 10px;
}

.login-table {
	width: 100%;
	border-collapse: collapse;
	background-color: #FFFFFF;
	border: 1px solid #B8B8B8;
	border-top: none;
}

.login-table-header {
	background-color: #CFCFCF;
	padding: 5px 0;
	text-align: center;
	font-weight: 700;
	font-size: 14px;
	line-height: 1.6em;
	letter-spacing: 0.05em;
	color: #151515;
	border: 1px solid #B8B8B8;
	border-bottom: none;
}

.login-table-label {
	background-color: #ECECEC;
	padding: 9.5px 61px 9.5px 0;
	text-align: right;
	font-weight: 700;
	font-size: 14px;
	line-height: 1.6em;
	letter-spacing: 0.05em;
	color: #333333;
	border: 1px solid #B8B8B8;
	border-top: none;
	border-right: none;
	width: 179.19px;
}

.login-table-input {
	padding: 3.72px 5.31px;
	border: 1px solid #B8B8B8;
	border-top: none;
	border-left: none;
}

.login-input {
	width: 100%;
	height: 34px;
	border: 1px solid #E0E0E0;
	padding: 0 10px;
	font-family: 'Noto Serif JP', serif;
	font-size: 14px;
	color: #333333;
	background-color: #FFFFFF;
}

.login-input:focus {
	outline: none;
	border-color: #A22324;
}

.forgot-password-link {
	display: block;
	margin-top: 10px;
	font-weight: 700;
	font-size: 14px;
	line-height: 1.6em;
	letter-spacing: 0.05em;
	color: #333333;
	text-decoration: none;
}

.forgot-password-link:hover {
	text-decoration: underline;
}

.login-submit-btn {
	width: 170px;
	height: 40px;
	margin-top: 20px;
	background-color: #1E1E1E;
	color: #FFFFFF;
	border: none;
	border-radius: 99px;
	font-family: 'Noto Serif JP', serif;
	font-weight: 700;
	font-size: 16px;
	line-height: 1.21875em;
	letter-spacing: 0.0625em;
	cursor: pointer;
	transition: background-color 0.3s ease;
}

.login-submit-btn:hover {
	background-color: #333333;
}

.login-right {
	padding-top: 0;
	width: 100%;
	max-width: 484px;
}

.registration-description {
	font-weight: 500;
	font-size: 14px;
	line-height: 1.6em;
	letter-spacing: 0.05em;
	color: #333333;
	margin: 10px 0 37px 0;
}

.registration-btn {
	display: inline-block;
	width: 170px;
	height: 40px;
	background-color: #1E1E1E;
	color: #FFFFFF;
	border: none;
	border-radius: 99px;
	font-family: 'Noto Serif JP', serif;
	font-weight: 700;
	font-size: 16px;
	line-height: 1.21875em;
	letter-spacing: 0.0625em;
	text-align: center;
	line-height: 40px;
	text-decoration: none;
	transition: background-color 0.3s ease;
}

.registration-btn:hover {
	background-color: #333333;
}

/* Responsive Styles for Login Page */
@media (max-width: 1024px) {
	.login-layout {
		grid-template-columns: 1fr;
		gap: 20px;
		max-width: 600px;
	}

	.login-left,
	.login-right {
		width: 100%;
	}
}

@media (max-width: 768px) {
	.login-layout {
		gap: 40px;
		padding: 0 20px;
	}

	.login-table {
		font-size: 12px;
	}

	.login-table-label {
		padding: 8px 20px 8px 0;
		font-size: 12px;
	}

	.login-input {
		height: 30px;
		font-size: 12px;
	}

	.login-submit-btn,
	.registration-btn {
		width: 100%;
		max-width: 300px;
	}
}

/* Register Page Styles */
.register-page-content {
	padding: 60px 0;
	background-color: var(--bg-color);
}

.register-page-header {
	max-width: 1000px;
	margin: 0 auto 60px;
	text-align: center;
}

.register-page-title {
	font-weight: 400;
	font-size: 32px;
	line-height: 1.7em;
	letter-spacing: 0.021875em;
	color: #333333;
	margin: 0 0 20px 0;
	font-family: 'Noto Serif JP', serif;
}

.register-page-separator {
	width: 100%;
	height: 1px;
	background-color: #000000;
	margin: 0 auto;
	max-width: 1000px;
}

.register-section {
	max-width: 1000px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
}

.register-section-title {
	font-weight: 700;
	font-size: 14px;
	line-height: 2.2857142857142856em;
	letter-spacing: 0.05em;
	color: #333333;
	margin: 0 0 30px 0;
}

.register-form {
	width: 450px;
}

.register-form-table {
	width: 100%;
	background-color: #FFFFFF;
	border: 1px solid #B8B8B8;
}

.register-form-row {
	display: flex;
	border-bottom: 1px solid #B8B8B8;
}

.register-form-row:last-child {
	border-bottom: none;
}

.register-form-label {
	width: 179.19px;
	background-color: #ECECEC;
	padding: 10px;
	text-align: right;
	font-weight: 700;
	font-size: 14px;
	line-height: 1.6em;
	letter-spacing: 0.05em;
	color: #333333;
	border-right: 1px solid #B8B8B8;
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 4px;
	flex-shrink: 0;
}

.register-form-label span:first-child {
	text-align: right;
}

.register-form-input-wrapper {
	flex: 1;
	padding: 5px;
	border-left: 1px solid #B8B8B8;
	position: relative;
}

.register-form-input {
	width: 100%;
	height: 34px;
	border: 1px solid #E0E0E0;
	padding: 0 10px;
	font-family: 'Noto Serif JP', serif;
	font-size: 14px;
	color: #333333;
	background-color: #FDFDFD;
	outline: none;
}

/* .register-form-input:focus {
	outline: none;
	border-color: #A22324;
} */

.register-form-input::placeholder {
	color: #C9C9C9;
}

.register-form-buttons {
	display: flex;
	gap: 0;
	margin-top: 30px;
	align-items: center;
	flex-direction: column;
	width: 100%;
}

.register-submit-btn {
	width: 450px;
	height: 32px;
	background-color: #CFCFCF;
	color: #151515;
	border: 1px solid #B49C69;
	text-align: center;
	font-weight: 700;
	font-size: 14px;
	line-height: 32px;
}

.register-confirm-btn {
	width: 170px;
	height: 40px;
	background-color: #1E1E1E;
	color: #FFFFFF;
	border: none;
	border-radius: 99px;
	font-family: 'Noto Serif JP', serif;
	font-weight: 700;
	font-size: 16px;
	line-height: 1.21875em;
	letter-spacing: 0.0625em;
	cursor: pointer;
	transition: background-color 0.3s ease;
	margin-top: 20px;
	align-self: flex-start;
}

.register-confirm-btn:hover {
	background-color: #333333;
}

.register-back-link {
	margin-top: 20px;
}

.register-back-link a {
	font-weight: 700;
	font-size: 14px;
	line-height: 1.6em;
	letter-spacing: 0.05em;
	color: #333333;
	text-decoration: none;
}

.register-back-link a:hover {
	text-decoration: underline;
}

/* Responsive Styles for Register Page */
@media (max-width: 1024px) {
	.register-section {
		padding: 0;
	}

	.register-form-label {
		width: 150px;
	}

	.register-form-buttons {
		flex-direction: column;
		align-items: flex-start;
	}

	.register-submit-btn {
		width: 100%;
	}
}

@media (max-width: 768px) {
	.register-page-title {
		font-size: 24px;
	}
	.register-form{
		width: 100%;
	}
	.register-form-row {
		flex-direction: column;
	}

	.register-form-label {
		width: 100%;
		text-align: left;
		padding: 10px;
		border-right: none;
		border-bottom: 1px solid #B8B8B8;
		justify-content: flex-start;
	}

	.register-form-input-wrapper {
		border-left: none;
		border-bottom: 1px solid #B8B8B8;
	}

	.register-form-input {
		height: 30px;
		font-size: 12px;
	}

	.register-submit-btn {
		width: 100%;
		height: 40px;
	}

	.register-confirm-btn {
		width: 100%;
	}
}

/* Custom & MICE Page Styles */
.custom-mice-page-banner {
	position: relative;
	width: 100%;
	height: 581px;
	margin-top: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
}

.custom-mice-page-banner .banner-background {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: linear-gradient(rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.3)),
		url('../images/27cd1735653cabb2b8cfd16095f8ee71745343e7.jpg') center/cover no-repeat;
	border-radius: 30px;
	z-index: 1;
	margin: 25px;
	width: calc(100% - 50px);
	height: calc(100% - 50px);
}

.custom-mice-page-banner .banner-content {
	position: relative;
	z-index: 2;
	width: 100%;
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 105px;
	color: var(--white);
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	padding-top: 134px;
	padding-bottom: 40px;
}

.custom-mice-page-banner .banner-title-section {
	position: absolute;
	left: 105px;
	bottom: 120px;
}

.custom-mice-page-banner .page-title {
	font-weight: 500;
	font-size: 35px;
	line-height: 1.6em;
	letter-spacing: 0.02em;
	margin: 0;
	color: var(--white);
}

.custom-mice-page-banner .page-subtitle {
	font-weight: 500;
	font-size: 14.5px;
	line-height: 2em;
	letter-spacing: 0.05em;
	color: var(--white);
	margin: 0;
}

.custom-mice-page-banner .user-icon-banner {
	position: absolute;
	right: 149px;
	top: 43px;
	width: 32px;
	height: 32px;
}

.custom-mice-page-content {
	padding: 60px 0;
	background-color: var(--bg-color);
}

.breadcrumb-nav {
	margin-bottom: 30px;
	font-size: 12px;
	line-height: 1.5em;
	letter-spacing: 0.125em;
}

.breadcrumb-link {
	color: #0B0C0D;
	text-decoration: none;
}

.breadcrumb-separator {
	color: #000000;
	margin: 0 5px;
}

.breadcrumb-current,
.breadcrumb-tab {
	color: #000000;
}

.custom-mice-description {
	display: flex;
	justify-content: center;
	align-items: center;
	margin-bottom: 30px;
}

.custom-mice-description-text {
	display: flex;
	align-items: center;
	gap: 4px;
	font-size: 7.734375px;
	line-height: 2.1333333333333333em;
	letter-spacing: 0.06464646464646465em;
}

.custom-mice-description-main {
	font-size: 14px;
	color: #000000;
	margin: 0;
}

.custom-mice-tab-nav {
	display: flex;
	gap: 0;
	max-width: 541px;
	margin: 0 auto 32px;
	border-radius: 0;
	border: 1px solid #F6F2EC;
}

.custom-mice-tab-item {
	flex: 1;
	padding: 10px;
	text-align: center;
	cursor: pointer;
	font-weight: 500;
	font-size: 20px;
	line-height: 1.5em;

	background-color: rgba(0, 0, 0, 0);
	border: none;
	transition: all 0.3s ease;
}
.custom-mice-tab-item a{
	text-decoration: none;
	color: #2D2D2D;
}
.custom-mice-tab-item.active a{
	color: #A22324;
	text-decoration: none;
}
.custom-mice-tab-item.active {

	background-color: #F6F2EC;
}

.custom-mice-layout {
	display: grid;
	grid-template-columns: 301px 1fr;
	gap: 80px;
	margin-top: 60px;
}

.custom-mice-sidebar {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.custom-mice-menu-item {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 10px;
	background-color: #F6F2EC;
	cursor: pointer;
	font-weight: 500;
	font-size: 16px;
	line-height: 1.8125015497207642em;
	letter-spacing: 0.04531246796250343em;
	color: #1E1E1E;
	transition: all 0.3s ease;
}
.narrow1{
	display: none;
}
.custom-mice-menu-item.active{
	color: #A22324;
}
.custom-mice-menu-item.active .narrow{
	display: none;
}
.custom-mice-menu-item.active .narrow1{
	display: block;
}

.custom-mice-menu-item:hover {
	background-color: #E8E4DD;
}

.custom-mice-form-section {
	flex: 1;
}

.custom-mice-form {
	width: 100%;
}

.form-section {
	margin-bottom: 25px;
	background-color: transparent;
	border-radius: 5px;
}

.form-section-title {
	font-weight: 700;
	font-size: 14px;
	line-height: 1.5em;
	color: #000000;
}

.form-subsection {
	margin-bottom: 20px;
}

.form-subsection-title {
	font-weight: 500;
	font-size: 14px;
	line-height: 1.5em;
	color: #000000;
	text-align: left;
}

.form-group {
	display: grid;
	grid-template-columns: 320px 1fr;
	gap: 20px;
	align-items: flex-start;
	margin-bottom: 16px;
}

.form-group:last-child {
	margin-bottom: 0;
}

.form-label {
	display: flex;
	align-items: center;
	gap: 4px;
	font-weight: 400;
	font-size: 14px;
	line-height: 40px;
	letter-spacing: 0.028571428997176036em;
	color: #000000;
	text-align: right;
	justify-content: flex-end;
}

.form-input,
.form-textarea {
	width: 100%;
	padding: 8px 12px;
	border: 1px solid #BFBFBF;
	border-radius: 5px;
	font-family: 'Noto Serif JP', serif;
	font-size: 14px;
	color: #000000;
	background-color: #FFFFFF;
	resize: none;
	outline: none;
}

.form-textarea {
	resize: vertical;
	min-height: 93px;
	resize: none;
	outline: none;
}

.checkbox-group,
.radio-group {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	align-items: center;
}
.checkbox-group.disb{
	display: block;
}

.checkbox-item,
.radio-item {
	display: flex;
	align-items: center;
	gap: 8px;
	cursor: pointer;
	font-weight: 500;
	font-size: 14px;
	line-height: 1.5em;
	color: #000000;
}
.checkbox-group.disb .checkbox-item{
	margin: 5px 0;
}
.checkbox-item input[type="checkbox"],
.radio-item input[type="radio"] {
	display: none;
}

.checkbox-circle,
.radio-circle {
	width: 13px;
	height: 13px;
	border: 1px solid #000000;
	border-radius: 50%;
	display: inline-block;
	position: relative;
	background-color: #D9D9D9;
}

.checkbox-item input[type="checkbox"]:checked+.checkbox-circle,
.radio-item input[type="radio"]:checked+.radio-circle {
	background-color: #000000;
}

.radio-item input[type="radio"]:checked+.radio-circle::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 5px;
	height: 5px;
	background-color: #FFFFFF;
	border-radius: 50%;
}

.form-input-inline {
	display: inline-block;
	width: 339px;
	padding: 8px 12px;
	border: 1px solid #BFBFBF;
	border-radius: 5px;
	font-family: 'Noto Serif JP', serif;
	font-size: 14px;
	color: #000000;
	background-color: #FFFFFF;
	margin-left: 10px;
	outline: none;
}

.form-submit-wrapper {
	margin: 40px 0 20px;
	text-align: center;
}

.form-submit-btn {
	width: 314px;
	height: 40px;
	background-color: #1E1E1E;
	color: #FFFFFF;
	border: none;
	border-radius: 99px;
	font-family: 'Noto Serif JP', serif;
	font-weight: 600;
	font-size: 16px;
	line-height: 1.21875em;
	letter-spacing: 0.0625em;
	cursor: pointer;
	transition: background-color 0.3s ease;
}

.form-submit-btn:hover {
	background-color: #333333;
}

.form-checkbox-wrapper {
	text-align: center;
	margin-bottom: 40px;
}

.form-checkbox-label {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	cursor: pointer;
	font-weight: 350;
	font-size: 14px;
	line-height: 1.5em;
	color: #333333;
}

.form-checkbox {
	display: none;
}

.checkbox-checkmark {
	width: 16px;
	height: 16px;
	border: 2px solid #A22324;
	border-radius: 99px;
	display: inline-block;
	position: relative;
}

.form-checkbox:checked+.checkbox-checkmark::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 8px;
	height: 8px;
	background-color: #A22324;
	border-radius: 50%;
}

.checkbox-text {
	color: #A22324;
}

/* Responsive Styles for Custom & MICE Page */
@media (max-width: 1024px) {
	.custom-mice-layout {
		grid-template-columns: 1fr;
		gap: 30px;
	}

	.custom-mice-sidebar {
		flex-direction: row;
		overflow-x: auto;
	}

	.custom-mice-menu-item {
		flex-shrink: 0;
		min-width: 200px;
	}

	.form-group {
		grid-template-columns: 1fr;
		gap: 10px;
	}

	.form-label {
		text-align: left;
		justify-content: flex-start;
	}
	.custom-mice-page-banner .banner-title-section {
		left: 30px;
		bottom: 60px;
	}
	.custom-mice-page-banner .page-title{
		font-size: 20px;
	}
	.custom-mice-page-content{
		padding: 30px 0;
	}
	.form-input-inline{
		flex: 1;
		width: auto;
	}
}

@media (max-width: 768px) {
	.custom-mice-page-banner {
		height: 400px;
	}

	.custom-mice-page-banner .banner-content {
		padding: 0 20px 40px;
	}

	.custom-mice-description {
		flex-direction: column;
		align-items: flex-start;
	}

	.custom-mice-description-main {
		margin-left: 0;
		margin-top: 10px;
	}

	.custom-mice-tab-nav {
		flex-direction: column;
	}

	.form-section {
		padding: 15px;
	}

	.checkbox-group,
	.radio-group {
		flex-direction: column;
		align-items: flex-start;
	}

	.form-submit-btn {
		width: 100%;
		max-width: 300px;
	}
}

/* Password Reset Page Styles */
.password-reset-page-content {
	padding: 60px 0;
	background-color: var(--bg-color);
}

.password-reset-header {
	max-width: 1000px;
	margin: 0 auto 30px;
}

.password-reset-title {
	font-weight: 600;
	font-size: 14px;
	line-height: 2.2857142857142856em;
	letter-spacing: 0.05em;
	color: #333333;
	margin: 0;
	font-family: 'Noto Serif JP', serif;
}

.password-reset-info-box {
	max-width: 520px;
	margin: 0 220px;
	background-color: #CFCFCF;
	height: 36px;
	display: flex;
	align-items: center;
	justify-content: center;
}
.zsdxtit {
	max-width: 520px;
	margin: 0 220px;
	font-weight: 600;
	font-size: 14px;
	line-height: 32px;
	letter-spacing: 0.7px;
	color: #333333;
}
.mt30{
	margin-top: 30px;
}
.mt22{
	margin-top: 22px;
}
.mt45{
	margin-top: 45px;
}
.password-reset-info-text {
	font-weight: 700;
	font-size: 14px;
	line-height: 2.5714285714285716em;
	letter-spacing: 0.05em;
	color: #151515;
	margin: 0;
	text-align: center;
	font-family: 'Noto Serif JP', serif;
}

.password-reset-form-wrapper {
	max-width: 520px;
	margin: 0 220px;
}

.password-reset-form {
	width: 100%;
}

.password-reset-table {
	width: 100%;
	border: 1px solid #B8B8B8;
	border-collapse: collapse;
	background-color: #FFFFFF;
}

.password-reset-row {
	border-bottom: 1px solid #B8B8B8;
}

.password-reset-row:last-child {
	border-bottom: none;
}

.password-reset-label-cell {
	width: 180px;
	background-color: #ECECEC;
	padding: 10px;
	text-align: right;
	font-weight: 700;
	font-size: 14px;
	color: #333333;
	border-right: 1px solid #B8B8B8;
}
.password-reset-label-cell span{
	color: #BC261A;
}
.password-reset-input-cell {
	padding: 3px;
	background-color: #FFFFFF;
	position: relative;
}
.eye{
	position: absolute;
	right: 14px;
	top: 50%;
	transform: translateY(-50%);
	padding: 5px;
}
.password-reset-input {
	width: 100%;
	height: 34px;
	border: 1px solid #ECECEC;
	padding: 0 10px;
	font-family: 'Noto Serif JP', serif;
	font-size: 14px;
	color: #333333;
	background-color: #FDFDFD;
	box-sizing: border-box;
	outline: none;
}

.password-reset-code-wrapper {
	display: flex;
	gap: 4px;
	align-items: center;
}

.password-reset-code-input {
	flex: 1;
	width: auto;
}

.password-reset-code-btn {
	width: 84.66px;
	height: 32px;
	background-color: #1E1E1E;
	color: #FFFFFF;
	border: none;
	border-radius: 99px;
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
	font-size: 14px;
	line-height: 1.437000002179827em;
	letter-spacing: 0.05em;
	cursor: pointer;
	transition: background-color 0.3s ease;
	flex-shrink: 0;
}

.password-reset-code-btn:hover {
	background-color: #333333;
}

.password-reset-submit-wrapper {
	margin-top: 20px;
	text-align: left;
}

.password-reset-submit-btn {
	width: 170px;
	height: 40px;
	background-color: #1E1E1E;
	color: #FFFFFF;
	border: none;
	border-radius: 99px;
	font-family: 'Noto Serif JP', serif;
	font-weight: 400;
	font-size: 16px;
	line-height: 1.437000036239624em;
	letter-spacing: 0.0625em;
	cursor: pointer;
	transition: background-color 0.3s ease;
}

.password-reset-submit-btn:hover {
	background-color: #333333;
}

.password-reset-back-link {
	max-width: 1000px;
	margin: 20px auto 0;
	text-align: left;
}

.password-reset-back {
	font-weight: 700;
	font-size: 14px;
	line-height: 1.5999999727521623em;
	letter-spacing: 0.05em;
	color: #333333;
	text-decoration: none;
	font-family: 'Noto Serif JP', serif;
}

.password-reset-back:hover {
	text-decoration: underline;
}

/* Responsive Styles for Password Reset Page */
@media (max-width: 1024px) {

	.password-reset-form-wrapper,
	.password-reset-info-box {
		max-width: 100%;
		padding: 0;
		margin: 0;
	}
	.mt45{
		margin-top: 20px;
	}

	.password-reset-label-cell {
		width: 150px;
		padding-right: 20px;
	}
}

@media (max-width: 768px) {
	.password-reset-page-content {
		padding: 40px 0;
	}

	.password-reset-title {
		font-size: 12px;
	}

	.password-reset-info-box {
		height: auto;
		padding: 10px;
	}

	.password-reset-info-text {
		font-size: 12px;
	}

	.password-reset-table {
		font-size: 12px;
	}

	.password-reset-label-cell {
		width: 120px;
		padding: 8px 10px;
		font-size: 12px;
	}

	.password-reset-input {
		height: 30px;
		font-size: 12px;
	}

	.password-reset-code-btn {
		width: 70px;
		height: 28px;
		font-size: 12px;
	}

	.password-reset-submit-btn {
		width: 100%;
		max-width: 200px;
	}
}

/* My Page Styles */
.mypage-content {
	padding: 60px 0;
	background-color: var(--bg-color);
}

.mypage-breadcrumb {
	max-width: 1000px;
	margin: 0 auto 30px;
	display: flex;
	align-items: center;
	gap: 5px;
	font-family: 'Noto Serif JP', serif;
}

.breadcrumb-link {
	font-weight: 400;
	font-size: 12px;
	line-height: 1.5em;
	letter-spacing: 0.125em;
	color: #0B0C0D;
	text-decoration: none;
}

.breadcrumb-link:hover {
	text-decoration: underline;
}

.breadcrumb-separator {
	font-weight: 400;
	font-size: 12px;
	line-height: 1.5em;
	letter-spacing: 0.125em;
	color: #000000;
}

.breadcrumb-current {
	font-weight: 400;
	font-size: 12px;
	line-height: 1.5em;
	letter-spacing: 0.125em;
	color: #000000;
	text-decoration: none;
}

.mypage-header {
	max-width: 1000px;
	margin: 0 auto 60px;
	text-align: center;
	border-bottom: 1px solid #000000;
	padding-bottom: 20px;
}

.mypage-title {
	font-weight: 400;
	font-size: 29.6171875px;
	line-height: 1.836771351968478em;
	letter-spacing: 0.023634924419446346em;
	color: #333333;
	margin: 0;
	font-family: 'Noto Serif JP', serif;
}

.mypage-menu {
	max-width: 1000px;
	margin: 0 auto;
}

.mypage-menu-item {
	margin-bottom: 40px;
}

.mypage-menu-item:last-child {
	margin-bottom: 0;
}

.mypage-menu-title {
	font-weight: 600;
	font-size: 16px;
	line-height: 32px;
	letter-spacing: 0.05em;
	color: #333333;
	text-decoration: underline;
	font-family: 'Avenir', 'Noto Serif JP', serif;
}

.mypage-menu-description {
	font-weight: 500;
	font-size: 12px;
	line-height: 32px;
	letter-spacing: 0.05em;
	color: #333333;
	margin: 0;
	font-family: 'Avenir', 'Noto Serif JP', serif;
}

/* Responsive Styles for My Page */
@media (max-width: 1024px) {
	.mypage-content {
		padding: 40px 0;
	}

	.mypage-breadcrumb,
	.mypage-header,
	.mypage-menu {
		max-width: 100%;
		padding: 0 20px;
	}
}

@media (max-width: 768px) {
	.mypage-title {
		font-size: 24px;
	}

	.mypage-menu-title,
	.mypage-menu-description {
		font-size: 12px;
	}

	.mypage-menu-item {
		margin-bottom: 30px;
	}
}

/* Cart Page Styles */
.cart-page-content {
	padding: 60px 0;
	background-color: var(--bg-color);
}

.cart-breadcrumb {
	max-width: 1000px;
	margin: 0 auto 30px;
	display: flex;
	align-items: center;
	gap: 5px;
	font-family: 'Noto Serif JP', serif;
}

.cart-header {
	max-width: 1000px;
	margin: 0 auto 40px;
	border-bottom: 1px solid #000000;
	padding-bottom: 20px;
}

.cart-header-content {
	display: flex;
	align-items: center;
	gap: 15px;
}

.cart-header-icon {
	width: 32px;
	height: 32px;
}

.cart-title {
	font-weight: 600;
	font-size: 29.6171875px;
	line-height: 1.836771351968478em;
	letter-spacing: 0.023634924419446346em;
	color: #333333;
	margin: 0;
	font-family: 'Noto Serif JP', serif;
}

.cart-content-wrapper {
	max-width: 1000px;
	margin: 0 auto;
}

.cart-card {
	/* background-color: #FFFFFF;
	border: 1px solid #E0E0E0;
	padding: 40px; */
	margin-bottom: 40px;
}

.cart-product-meta {
	display: flex;
	align-items: center;
	gap: 15px;
	margin-top: 10px;
	flex-wrap: wrap;
}

.cart-meta-item {
	display: flex;
	align-items: center;
	gap: 6px;
	font-weight: 400;
	font-size: 14px;
	line-height: 1.5em;
	color: #6E6E6E;
	font-family: 'Noto Serif JP', serif;
}

.cart-meta-icon {
	width: 15px;
	height: 15px;
	flex-shrink: 0;
}

.cart-location-icon {
	width: 12px;
	height: 15px;
	flex-shrink: 0;
}

.cart-person-icon {
	width: 17px;
	height: 17px;
	flex-shrink: 0;
}

.cart-people-info {
	display: flex;
	align-items: center;
	gap: 15px;
	margin-top: 10px;
	flex-wrap: wrap;
}

.cart-people-text {
	font-weight: 500;
	font-size: 14px;
	line-height: 1.7142857142857142em;
	color: #333333;
	font-family: 'Noto Serif JP', serif;
}

.cart-image-vehicle {
	background-color: #FFFFFF;
}

.cart-table-wrapper {
	margin-bottom: 30px;
}

.cart-table-title {
	font-weight: 600;
	font-size: 16px;
	line-height: 50px;
	color: #000000;
	text-align: center;
	background-color: #CFCFCF;
	/* margin: 0 0 20px 0; */
	font-family: 'Noto Serif JP', serif;
}

.cart-table {
	width: 100%;
	border-collapse: collapse;
}

.cart-th {
	font-weight: 600;
	font-size: 15px;
	line-height: 1.759999974568685em;
	color: #7D7D7D;
	text-align: center;
	padding: 15px 10px;
	background-color: #F7F7F7;
	border-right: 1px solid #E0E0E0;
	border-bottom: 1px solid #E0E0E0;
	font-family: 'Noto Serif JP', serif;
}

.cart-row {
	border-bottom: 1px solid #E0E0E0;
}

.cart-row:last-child {
	border-bottom: none;
}

.cart-td {
	padding: 20px 10px;
	vertical-align: middle;
	text-align: center;
	background-color: #ffffff;
	border-right: 1px solid #E0E0E0;
}

.cart-td-product {
	text-align: left;
}

.cart-product-info {
	display: flex;
	align-items: center;
	gap: 15px;
	text-align: left;
}

.cart-product-image {
	width: 132.48px;
	height: 105px;
	background-color: #F7F7F7;
	border: 1px solid #E0E0E0;
	flex-shrink: 0;
	overflow: hidden;
}

.cart-product-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.cart-image-placeholder {
	width: 100%;
	height: 100%;
	background-color: #F7F7F7;
	border: 1px solid #E0E0E0;
}

.cart-product-details {
	flex: 1;
	min-width: 0;
}

.cart-product-name {
	font-weight: 600;
	font-size: 16px;
	line-height: 1.5em;
	letter-spacing: 0.04374999925494194em;
	text-transform: uppercase;
	color: #333333;
	margin: 0 0 8px 0;
	font-family: 'Noto Serif JP', serif;
}

.cart-product-location {
	font-weight: 400;
	font-size: 14px;
	line-height: 1.7142857142857142em;
	letter-spacing: 0.05em;
	color: #333333;
	margin: 0;
	font-family: 'Noto Serif JP', serif;
}

.cart-date {
	font-weight: 400;
	font-size: 16px;
	line-height: 2em;
	letter-spacing: 0.04374999925494194em;
	color: #333333;
	font-family: 'Noto Serif JP', serif;
}

.cart-quantity-control {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0;
}

.cart-quantity-btn {
	width: 50px;
	height: 34px;
	border: 1px solid #CBCBCB;
	background-color: #FFFFFF;
	color: #333333;
	font-weight: 400;
	font-size: 14px;
	line-height: 1.4285714285714286em;
	letter-spacing: 0.05em;
	cursor: pointer;
	transition: background-color 0.3s ease;
	font-family: 'Noto Serif JP', serif;
	display: flex;
	align-items: center;
	justify-content: center;
}

.cart-quantity-btn:hover {
	background-color: #F7F7F7;
}

.cart-quantity-input {
	width: 50px;
	height: 34px;
	border: 1px solid #CBCBCB;
	text-align: center;
	font-weight: 400;
	font-size: 14px;
	line-height: 1.4285714285714286em;
	letter-spacing: 0.05em;
	color: #333333;
	font-family: 'Noto Serif JP', serif;
	-moz-appearance: textfield;
	outline: none;
}

.cart-quantity-decrease {
	border-radius: 0;
}

.cart-quantity-increase {
	border-radius: 0;
}

.cart-subtotal {
	font-weight: 400;
	font-size: 16px;
	line-height: 2em;
	letter-spacing: 0.04374999925494194em;
	color: #333333;
	font-family: 'Noto Serif JP', serif;
}

.cart-cancel-btn {
	width: 85px;
	height: 34px;
	background-color: #F7F7F7;
	border: 1px solid #CBCBCB;
	color: #333333;
	font-weight: 400;
	font-size: 14px;
	line-height: 1.4285714285714286em;
	letter-spacing: 0.05em;
	cursor: pointer;
	transition: background-color 0.3s ease;
	font-family: 'Noto Serif JP', serif;
}

.cart-cancel-btn:hover {
	background-color: #E0E0E0;
}

.cart-actions {
	margin-bottom: 30px;
	text-align: right;
}

.cart-clear-btn {
	width: 123px;
	height: 33px;
	background-color: #1E1E1E;
	border: none;
	border-radius: 99px;
	color: #FFFFFF;
	font-weight: 500;
	font-size: 12px;
	line-height: 2.6666666666666665em;
	letter-spacing: 0.05833333233992258em;
	cursor: pointer;
	transition: background-color 0.3s ease;
	font-family: 'Noto Serif JP', serif;
}

.cart-clear-btn:hover {
	background-color: #333333;
}

.cart-summary {
	margin-bottom: 30px;
	text-align: right;
}

.cart-summary-row {
	/* display: flex;
	justify-content: space-between;
	align-items: center; */
	font-size: 0;
}

.cart-summary-label-wrapper {
	width: 214px;
	height: 45px;
	background-color: #F7F7F7;
	border: 1px solid #CBCBCB;
	display: inline-flex;
	align-items: center;
	justify-content: flex-end;
	padding-right: 10px;
	vertical-align: middle;
}

.cart-summary-label {
	font-weight: 400;
	font-size: 14px;
	line-height: 1.4285714285714286em;
	letter-spacing: 0.05em;
	color: #333333;
	font-family: 'Noto Serif JP', serif;
}

.cart-summary-amount-wrapper {
	width: 309px;
	height: 45px;
	vertical-align: middle;
	display: inline-block;
	flex: 1;
	text-align: right;
	padding-right: 20px;
	background-color: #ffffff;
	border: 1px solid #E0E0E0;
	border-left: none;
	padding: 7px 10px;
}
.cartjus{
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.cart-summary-amount {
	font-weight: 400;
	font-size: 16px;
	line-height: 2em;
	letter-spacing: 0.04374999925494194em;
	color: #333333;
	font-family: 'Noto Serif JP', serif;
}

.cart-reserve-wrapper {
	margin-bottom: 0;
	text-align: center;
}

.cart-reserve-btn {
	width: 524px;
	height: 56px;
	background-color: #1E1E1E;
	border: none;
	border-radius: 99px;
	color: #FFFFFF;
	font-weight: 700;
	font-size: 16px;
	line-height: 1.5em;
	letter-spacing: 0.04374999925494194em;
	cursor: pointer;
	transition: background-color 0.3s ease;
	font-family: 'Noto Serif JP', serif;
}

.cart-reserve-btn:hover {
	background-color: #333333;
}

.cart-back-link {
	display: flex;
	align-items: center;
	gap: 15px;
	justify-content: center;
}

.cart-back-arrow {
	width: 5px;
	height: 8px;
	flex-shrink: 0;
}

.cart-back-text {
	font-weight: 400;
	font-size: 12px;
	line-height: 1.625em;
	letter-spacing: 0.016666666915019352em;
	color: #040404;
	text-decoration: none;
	font-family: 'Noto Serif JP', serif;
}

.cart-back-text:hover {
	text-decoration: underline;
}

/* Responsive Styles for Cart Page */
@media (max-width: 1024px) {

	.cart-content-wrapper,
	.cart-header,
	.cart-breadcrumb {
		max-width: 100%;
		/* padding: 0 20px; */
	}

	.cart-card {
		/* padding: 30px 20px; */
	}

	.cart-product-info {
		flex-direction: column;
		align-items: flex-start;
	}

	.cart-product-image {
		width: 100%;
		max-width: 200px;
	}
}

@media (max-width: 768px) {
	.cart-page-content {
		padding: 40px 0;
	}

	.cart-title {
		font-size: 24px;
	}

	.cart-card {
		/* padding: 20px 15px; */
	}

	.cart-table {
		font-size: 12px;
	}

	.cart-th,
	.cart-td {
		padding: 10px 3px;
	}

	.cart-product-image {
		width: 80px;
		height: 60px;
	}

	.cart-quantity-btn {
		width: 40px;
		height: 30px;
		font-size: 12px;
	}

	.cart-quantity-input {
		width: 40px;
		height: 30px;
		font-size: 12px;
	}
	
	.cart-cancel-btn {
		width: 70px;
		height: 30px;
		font-size: 12px;
	}

	.cart-reserve-btn {
		width: 170px;
		max-width: 400px;
	}

	.cart-summary-label-wrapper {
		width: 150px;
		height: 40px;
	}
	.cart-summary-amount-wrapper{
		width: 170px;
		height: 40px;
	}
}

/* Reservation Page Styles */
.reservation-page-banner {
	position: relative;
	width: 100%;
	height: 347px;
	margin-top: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	margin-bottom: 0;
	padding-top: 91px;
}

.reservation-page-banner .banner-background {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: linear-gradient(rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.3)),
		url('../images/27cd1735653cabb2b8cfd16095f8ee71745343e7.jpg') center/cover no-repeat;
	border-radius: 0;
	z-index: 1;
}

.reservation-page-banner .banner-content {
	position: relative;
	z-index: 2;
	width: 100%;
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 220px;
	color: var(--white);
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}

.reservation-page-banner .banner-title-section {
	text-align: center;
}

.reservation-page-banner .page-title {
	font-weight: 400;
	font-size: 29.6171875px;
	line-height: 1.836771351968478em;
	letter-spacing: 0.023634924419446346em;
	margin: 0;
	color: #333333;
	text-align: center;
}

.reservation-page-banner .page-subtitle {
	font-family: 'EB Garamond', serif;
	font-weight: 400;
	font-size: 14px;
	line-height: 1.1999999455043249em;
	letter-spacing: 0.09999999829701014em;
	color: #1A1918;
	margin: 0;
	text-align: center;
}

.reservation-page-content {
	padding: 0;
	background-color: var(--bg-color);
}

.reservation-breadcrumb {
	display: flex;
	align-items: center;
	gap: 0;
	padding: 20px 220px;
	font-size: 12px;
	line-height: 1.5em;
	letter-spacing: 0.125em;
}

.reservation-breadcrumb .breadcrumb-link {
	color: #0B0C0D;
	text-decoration: none;
}

.reservation-breadcrumb .breadcrumb-separator {
	color: #000000;
	margin: 0 5px;
}

.reservation-breadcrumb .breadcrumb-current {
	color: #000000;
}

.reservation-products {
	margin-top: 45px;
	display: flex;
	flex-direction: column;
	gap: 32px;
	padding: 0 237px;
	margin-bottom: 32px;
}

.reservation-product-card {
	display: flex;
	gap: 25px;
	background-color: #F6F6F5;
	padding: 20px;
	border-radius: 0;
}

.reservation-product-image {
	width: 237.5px;
	height: 193.8px;
	flex-shrink: 0;
	overflow: hidden;
	border-radius: 0;
}

.reservation-product-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.reservation-product-info {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.reservation-product-title {
	font-weight: 500;
	font-size: 24px;
	line-height: 1.25em;
	letter-spacing: 0.041666666666666664em;
	color: #1C1C1C;
	margin: 0;
}

.reservation-product-location {
	font-weight: 400;
	font-size: 16px;
	line-height: 1.125em;
	color: #737373;
	margin: 0;
}

.reservation-product-meta {
	display: flex;
	align-items: center;
	gap: 20px;
	flex-wrap: wrap;
}

.reservation-meta-item {
	display: flex;
	align-items: center;
	gap: 6px;
	font-weight: 400;
	font-size: 14px;
	line-height: 1.5em;
	color: #6E6E6E;
}

.reservation-meta-icon {
	width: 15px;
	height: 15px;
	flex-shrink: 0;
}

.reservation-location-icon {
	width: 12px;
	height: 15px;
	flex-shrink: 0;
}

.reservation-person-icon {
	width: 17px;
	height: 17px;
	flex-shrink: 0;
}

.reservation-product-details {
	display: flex;
	flex-direction: column;
	gap: 8px;
	margin-top: 10px;
}

.reservation-detail-text {
	font-weight: 500;
	font-size: 16px;
	line-height: 1.5em;
	color: #111111;
	margin: 0;
}

.reservation-detail-text-light {
	font-weight: 500;
	font-size: 14px;
	line-height: 1.7142857142857142em;
	color: #111111;
}

.reservation-price-summary {
	background-color: #F6F6F5;
	padding: 30px;
	margin: 32px 237px ;
	border-radius: 0;
}

.reservation-price-header {
	margin-bottom: 10px;
}

.reservation-price-divider {
	height: 1px;
	background-color: #DBDBDB;
	margin-bottom: 10px;
}

.reservation-price-total {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 20px;
}

.reservation-price-label {
	font-family: 'Fira Sans', sans-serif;
	font-weight: 500;
	font-size: 20px;
	line-height: 1.3em;
	color: #201F1D;
	margin: 0;
}

.reservation-price-amount {
	font-family: 'Fira Sans', sans-serif;
	font-weight: 500;
	font-size: 20px;
	line-height: 1.3em;
	color: #000000;
	margin: 0;
}
.reservation-price-amount span{
	font-size: 28px;
	color: #E00000;
	font-weight: bold;
}
.reservation-price-details {
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin-bottom: 20px;
}

.reservation-price-item {
	display: flex;
	flex-direction: column;
	gap: 5px;
}

.reservation-price-item-label {
	font-weight: 600;
	font-size: 16px;
	line-height: 1.625em;
	color: #201F1D;
}

.reservation-price-item-quantity {
	font-weight: 600;
	font-size: 16px;
	line-height: 1.625em;
	color: #201F1D;
}

.reservation-payment-section {
	display: flex;
	align-items: center;
	gap: 20px;
	padding-top: 20px;
	border-top: 1px solid #DBDBDB;
}

.reservation-payment-label {
	font-weight: 700;
	font-size: 15px;
	line-height: 1.5em;
	color: #2F2F2F;
	margin: 0;
}

.reservation-payment-icons {
	display: flex;
	align-items: center;
	gap: 16px;
}

.reservation-payment-icon {
	width: 46px;
	height: 30px;
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: #FFFFFF;
	border-radius: 4px;
	overflow: hidden;
}

.reservation-payment-icon img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.reservation-payment-btn {
	margin-left: auto;
	background-color: #1E1E1E;
	color: #FFFFFF;
	border: 1px solid #FFFFFF;
	border-radius: 99px;
	padding: 12.5px 41px;
	font-weight: 600;
	font-size: 16px;
	line-height: 1.5em;
	cursor: pointer;
	display: flex;
	align-items: center;
	gap: 10px;
}

.reservation-payment-btn span {
	font-weight: 700;
	font-size: 16px;
}

.reservation-booking-form {
	background-color: #F6F6F5;
	padding: 30px;
	margin: 0 237px;
	border-radius: 0;
}

.reservation-form-header {
	margin-bottom: 30px;
}

.reservation-form-title {
	font-weight: 600;
	font-size: 20px;
	line-height: 1.2em;
	color: #201F1D;
	margin: 0;
}

.reservation-form-checkbox-wrapper {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-left: 20px;
}

.reservation-form-checkbox {
	width: 18px;
	height: 18px;
	border: 1px solid #5C7246;
	background-color: #FFFFFF;
	cursor: pointer;
}

.reservation-form-checkbox-label {
	font-weight: 600;
	font-size: 14px;
	line-height: 1.7142857142857142em;
	color: #201F1D;
	cursor: pointer;
}

.reservation-form-divider {
	height: 1px;
	background-color: #DBDBDB;
	margin-top: 20px;
}

.reservation-form {
	margin-top: 30px;
}

.reservation-form-grid {
	display: grid;
	grid-template-columns: 380px 430px;
	gap: 17px 17px;
}

.reservation-form-group {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.reservation-form-group-full {
	grid-column: 1 / -1;
}

.reservation-form-label {
	font-weight: 700;
	font-size: 15px;
	line-height: 1.5em;
	color: #2F2F2F;
}

.reservation-form-label span {
	color: #FF0000;
}

.reservation-form-input,
.reservation-form-textarea {
	width: 100%;
	padding: 16px 14px;
	border: 1px solid #F4F4F4;
	background-color: #FFFFFF;
	font-family: 'Noto Serif JP', serif;
	font-weight: 400;
	font-size: 14px;
	line-height: 1.437000002179827em;
	color: rgba(33, 37, 41, 0.75);
	border-radius: 0;
	outline: none;
	resize: none;
}

.reservation-form-input::placeholder,
.reservation-form-textarea::placeholder {
	color: rgba(33, 37, 41, 0.75);
}

.reservation-form-textarea {
	height: 112px;
	resize: vertical;
	line-height: 1.2000000817435128em;
	resize: none;
}

/* Responsive Styles for Reservation Page */
@media (max-width: 1024px) {
	.reservation-products {
		padding: 0 20px;
	}

	.reservation-product-card {
		flex-direction: column;
	}

	.reservation-product-image {
		width: 100%;
		height: 200px;
	}

	.reservation-price-summary {
		margin: 32px 20px ;
	}

	.reservation-booking-form {
		margin: 0 20px;
	}

	.reservation-form-grid {
		grid-template-columns: 1fr;
	}

	.reservation-breadcrumb {
		padding: 20px;
	}

	.reservation-page-banner {
		padding: 0 20px;
	}

	.reservation-page-banner .banner-content {
		padding: 0 20px;
	}
}

@media (max-width: 768px) {
	.reservation-payment-section {
		flex-direction: column;
		align-items: flex-start;
	}

	.reservation-payment-btn {
		margin-left: 0;
		width: 100%;
		justify-content: center;
	}

	.reservation-product-meta {
		flex-direction: column;
		align-items: flex-start;
		gap: 10px;
	}
}

/* Reservation History Page Styles */
.reservation-history-banner {
	position: relative;
	width: 100%;
	height: 347px;
	margin-top: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	margin-bottom: 0;
	padding-top: 91px;
}

.reservation-history-banner .banner-background {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: linear-gradient(rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.3)),
		url('../images/27cd1735653cabb2b8cfd16095f8ee71745343e7.jpg') center/cover no-repeat;
	border-radius: 0;
	z-index: 1;
}

.reservation-history-banner .banner-content {
	position: relative;
	z-index: 2;
	width: 100%;
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 220px;
	color: var(--white);
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}

.reservation-history-banner .banner-title-section {
	text-align: center;
}

.reservation-history-banner .page-title {
	font-weight: 400;
	font-size: 29.6171875px;
	line-height: 1.836771351968478em;
	letter-spacing: 0.023634924419446346em;
	margin: 0;
	color: #333333;
	text-align: center;
}

.reservation-history-banner .page-subtitle {
	font-family: 'EB Garamond', serif;
	font-weight: 400;
	font-size: 14px;
	line-height: 1.1999999455043249em;
	letter-spacing: 0.09999999829701014em;
	color: #1A1918;
	margin: 0;
	text-align: center;
}

.reservation-history-content {
	padding: 0;
	background-color: var(--bg-color);
}

.reservation-history-breadcrumb {
	display: flex;
	align-items: center;
	gap: 0;
	padding: 20px 220px;
	font-size: 12px;
	line-height: 1.5em;
	letter-spacing: 0.125em;
}

.reservation-history-breadcrumb .breadcrumb-link {
	color: #0B0C0D;
	text-decoration: none;
}

.reservation-history-breadcrumb .breadcrumb-separator {
	color: #000000;
	margin: 0 5px;
}

.reservation-history-breadcrumb .breadcrumb-current {
	color: #000000;
}

.reservation-history-list {
	margin-top: 45px;
	display: flex;
	flex-direction: column;
	gap: 32px;
	padding: 0 237px;
	margin-bottom: 60px;
}

.reservation-history-card {
	background-color: #F6F6F5;
	border-radius: 10px;
	padding: 30px;
}

.reservation-history-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 20px;
}

.reservation-history-header-info {
	display: flex;
	gap: 20px;
}

.reservation-history-date,
.reservation-history-number {
	font-family: 'Fira Sans', sans-serif;
	font-weight: 700;
	font-size: 16px;
	line-height: 1.5em;
	color: #111111;
	margin: 0;
}
.reservation-history-date span{
	font-weight: normal;
}
.reservation-history-number span{
	font-weight: normal;
	color: #111111;
}
.reservation-history-total {
	font-weight: 700;
	font-size: 16px;
	line-height: 1.5em;
	color: #111111;
	margin: 0;
	text-align: right;
}

.reservation-history-divider {
	height: 1px;
	background-color: #DBDBDB;
	margin: 20px 0;
}

.reservation-history-products {
	display: flex;
	flex-direction: column;
	gap: 20px;
	margin-bottom: 20px;
}

.reservation-history-product {
	display: flex;
	gap: 16px;
}

.reservation-history-product-image {
	width: 119px;
	height: 95px;
	flex-shrink: 0;
	overflow: hidden;
	border-radius: 0;
}

.reservation-history-product-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.reservation-history-product-info {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.reservation-history-product-header {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
}

.reservation-history-product-title {
	font-weight: 600;
	font-size: 16px;
	line-height: 1.5em;
	color: #212121;
	margin: 0;
}

.reservation-history-product-price {
	font-weight: 700;
	font-size: 32px;
	line-height: 0.8999999761581421em;
	color: #FF0000;
	margin: 0;
}

.reservation-history-product-location {
	font-weight: 400;
	font-size: 16px;
	line-height: 1.125em;
	color: #737373;
	margin: 0;
}

.reservation-history-product-meta {
	display: flex;
	align-items: center;
	gap: 20px;
	flex-wrap: wrap;
}

.reservation-history-meta-item {
	display: flex;
	align-items: center;
	gap: 6px;
	font-weight: 400;
	font-size: 14px;
	line-height: 1.5em;
	color: #6E6E6E;
}

.reservation-history-meta-icon {
	width: 15px;
	height: 15px;
	flex-shrink: 0;
}

.reservation-history-location-icon {
	width: 12px;
	height: 15px;
	flex-shrink: 0;
}

.reservation-history-person-icon {
	width: 17px;
	height: 17px;
	flex-shrink: 0;
}

.reservation-history-product-details {
	display: flex;
	flex-direction: row;
	gap: 15px;
	margin-top: 4px;
	flex-wrap: wrap;
}

.reservation-history-detail-text {
	font-weight: 500;
	font-size: 14px;
	line-height: 1.7142857142857142em;
	color: #111111;
	margin: 0;
	white-space: nowrap;
}

.reservation-history-booking-info {
	margin-top: 20px;
}

.reservation-history-booking-title {
	font-weight: 600;
	font-size: 14px;
	line-height: 1.7142857142857142em;
	color: #111111;
	margin: 0 0 10px 0;
}

.reservation-history-booking-divider {
	height: 1px;
	background-color: #DBDBDB;
	margin: 10px 0;
}

.reservation-history-booking-content {
	font-weight: 400;
	font-size: 14px;
	line-height: 1.7142857142857142em;
	color: #111111;
}

.reservation-history-booking-content p {
	margin: 0 0 4px 0;
}

/* Responsive Styles for Reservation History Page */
@media (max-width: 1024px) {
	.reservation-history-list {
		padding: 0 20px;
	}

	.reservation-history-product {
		flex-direction: column;
	}

	.reservation-history-product-image {
		width: 100%;
		height: 200px;
	}

	.reservation-history-breadcrumb {
		padding: 20px;
	}

	.reservation-history-banner {
		padding: 0 20px;
	}

	.reservation-history-banner .banner-content {
		padding: 0 20px;
	}

	.reservation-history-header {
		flex-direction: column;
		align-items: flex-start;
		gap: 10px;
	}

	.reservation-history-header-info {
		flex-direction: column;
		gap: 5px;
	}
}

@media (max-width: 768px) {
	.reservation-history-product-meta {
		flex-direction: column;
		align-items: flex-start;
		gap: 10px;
	}

	.reservation-history-product-header {
		flex-direction: column;
		align-items: flex-start;
	}
}

/* Register Info Page Styles */
.register-info-banner {
	position: relative;
	width: 100%;
	height: 137px;
	margin-top: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	margin-bottom: 0;
}
.regtitle{
	margin: 0 220px;
	margin-top: 78px;
	padding-bottom: 40px;
	border-bottom: 1px solid #000000;
	font-weight: 600;
	font-size: 29.62px;
	line-height: 54.4px;
	letter-spacing: 0.7px;
	color: #333333;
}
.texc{
	text-align: center;
}
.regtitle1{
	margin: 0 220px;
	margin-top: 14px;
	padding-bottom: 40px;
	border-bottom: 1px solid #000000;
	font-weight: 600;
	font-size: 29.62px;
	line-height: 1;
	letter-spacing: 0.7px;
	color: #333333;
	text-align: center;
}
.regtitle2{
	margin-top: 30px;
	font-size: 14px;
	line-height: 16.8px;
	letter-spacing: 1;
	text-align: center;
	color: #1A1918;
}
.art{
	padding: 0 250px;
}
.art1{
	margin-top: 50px;
	font-weight: 700;
	font-style: Bold;
	font-size: 16px;
	line-height: 32px;
	color: #1A1918;
}
.art2{
	font-weight: 500;
	font-size: 14px;
	line-height: 32px;
	color: #1A1918;
}
.register-info-banner .banner-background {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: linear-gradient(rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.3)),
		url('../images/27cd1735653cabb2b8cfd16095f8ee71745343e7.jpg') center/cover no-repeat;
	border-radius: 0;
	z-index: 1;
}

.register-info-banner .banner-content {
	position: relative;
	z-index: 2;
	width: 100%;
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 220px;
	color: var(--white);
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}

.register-info-banner .banner-title-section {
	text-align: center;
}

.register-info-banner .page-title {
	font-weight: 600;
	font-size: 29.6171875px;
	line-height: 1.836771351968478em;
	letter-spacing: 0.023634924419446346em;
	margin: 0;
	color: #333333;
	text-align: center;
}

.register-info-content {
	padding: 0;
	background-color: var(--bg-color);
}

.register-info-page-header {
	width: 100%;
	max-width: 1000px;
	margin: 0 auto;
	padding: 0 220px;
	padding-top: 30px;
	padding-bottom: 20px;
}

.register-info-header-divider {
	height: 1px;
	background-color: #000000;
}

.register-info-breadcrumb {
	display: flex;
	align-items: center;
	gap: 0;
	padding: 20px 220px;
	font-size: 12px;
	line-height: 1.5em;
	letter-spacing: 0.125em;
}

.register-info-breadcrumb .breadcrumb-link {
	color: #0B0C0D;
	text-decoration: none;
}

.register-info-breadcrumb .breadcrumb-separator {
	color: #000000;
	margin: 0 5px;
}

.register-info-breadcrumb .breadcrumb-current {
	color: #000000;
}

.register-info-description {
	font-weight: 600;
	font-size: 14px;
	line-height: 3.8857143947056363em;
	letter-spacing: 0.04999999914850507em;
	color: #333333;
	margin: 0 0 30px 0;
	padding: 0 220px;
	margin-top: 45px;
}

.register-info-table {
	width: 100%;
	/* max-width: 997px; */
	margin: 0 auto 30px;
	padding: 0 220px;
	border-collapse: collapse;
}

.register-info-row {
	display: flex;
	width: 100%;
	height: 40px;
	border: 1px solid #CBCBCB;
}

.register-info-label {
	width: 262px;
	background-color: #ECECEC;
	border-right: 1px solid #CBCBCB;
	display: flex;
	align-items: center;
	justify-content: flex-end;
	padding: 5px 20px;
	font-weight: 600;
	font-size: 14px;
	line-height: 1.4285714285714286em;
	letter-spacing: 0.04999999914850507em;
	color: #333333;
	flex-shrink: 0;
}
.register-info-label span{
	color: #BC261A;
}
.register-info-value {
	flex: 1;
	background-color: #FFFFFF;
	display: flex;
	align-items: center;
	font-weight: 400;
	line-height: 1.4285714285714286em;
	letter-spacing: 0.04999999914850507em;
	color: #333333;
	padding: 3px;
}
.register-info-value span{
	display: block;
	width: 100%;
	padding: 6px 20px;
	font-size: 14px;
}
.register-info-value input{
	width: 164px;
	height: 34px;
	padding: 0 6px;
	color: #333333;
	font-size: 14px;
	border: 1px solid #CBCBCB;
	outline: none;
}
.register-info-value input.chaddr{
	width: 332px;
}
.register-info-value code{
	font-family: inherit;
	line-height: 34px;
	display: block;
	width: 100%;
	height: 34px;
	padding: 0 6px;
	font-size: 14px;
}
.back{
	padding: 0 220px;
}

.register-info-actions {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 20px;
	padding: 0 220px 60px;
}

.register-info-edit-btn {
	background-color: #1E1E1E;
	color: #FFFFFF;
	border: none;
	border-radius: 99px;
	padding: 10px 70.81px;
	font-weight: 600;
	font-size: 16px;
	line-height: 1.21875em;
	letter-spacing: 0.0625em;
	cursor: pointer;
	height: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.register-info-back-link {
	display: flex;
	align-items: center;
	gap: 8px;
	text-decoration: none;
	color: #040404;
	font-weight: 400;
	font-size: 12px;
	line-height: 1.625em;
	letter-spacing: 0.016666666915019352em;
}

.register-info-back-arrow {
	width: 5px;
	height: 8px;
	flex-shrink: 0;
}

.register-info-back-text {
	color: #040404;
}

/* Responsive Styles for Register Info Page */
@media (max-width: 1024px) {
	.register-info-table {
		max-width: 100%;
		margin: 0 0 20px;
		padding: 0;
	}

	.register-info-breadcrumb {
		padding: 20px;
	}

	.register-info-description {
		padding: 0;
		margin: 20px 0;
	}

	.register-info-actions {
		padding: 0 20px 30px;
		flex-direction: column;
	}

	.register-info-edit-btn {
		width: 100%;
		max-width: 300px;
	}

	.register-info-page-header {
		padding: 20px;
		padding-top: 30px;
	}

	.register-info-banner {
		padding: 0 20px;
		height: 90px;
	}

	.register-info-banner .banner-content {
		padding: 0 20px;
	}
	.regtitle {
		margin: 0;
		margin-top: 30px;
		padding-bottom: 20px;
		font-size: 18px;
		line-height: 30px;
	}
	.regtitle1{
		margin: 0;
		margin-top: 30px;
		padding-bottom: 20px;
		font-size: 18px;
		line-height: 30px;
	}
	.back{
		padding: 0;
	}
	.register-info-value input{
		width: 100%;
	}
	.register-info-value input.chaddr{
		width: 100%;
	}
	


}

@media (max-width: 900px) {
	.art{
		padding: 0;
	}
	.art1{
		margin-top: 20px;
	}










}

@media (max-width: 768px) {
	.register-info-row {
		flex-direction: column;
		height: auto;
	}

	.register-info-label {
		width: 100%;
		justify-content: flex-start;
		border-right: none;
		border-bottom: 1px solid #CBCBCB;
	}

	.register-info-value {
		width: 100%;
	}
}
.tips_tc{
	display: none;
	position: fixed;
	left: 50%;
	top: 50%;
	z-index: 999999;
	transform: translate(-50%,-50%);
	overflow: hidden;
	width: 80%;
	max-width: 690px;
	box-shadow: 0px 4px 21.100000381469727px 0px rgba(0, 0, 0, 0.1);
}
.tips_tc1{
	height: 56px;
	background-color: #1e1e1e;
	font-size: 22px;
	font-weight: 600;
	text-align: center;
	line-height: 56px;
	color: #ffffff;
}
.tips_tc2{
	background-color: #ffffff;
	padding: 26px 25px 23px;
}
.tips_tc3{
	font-size: 16px;
	font-weight: 700;
	line-height: 32px;
	text-align: center;
	color: #333333;
	min-height: 58px;
}