@charset "utf-8";

/**
 * program 投稿専用スタイル（モバイルファースト）
 */

.page-hero__button-link {
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	overflow: hidden;
	width: 83.71501vw;
	max-width: 420px;
	height: 56px;
	margin: 48px auto 0;
	background: url(../images/bg-btn.png) no-repeat center / cover;
	border: 1px solid #937946;
	color: var(--color-white);
	font-size: min(4.58015vw, 1rem);
}

.single-program .page-content {
	padding-top: 120px !important;
}

.program .page-content.program-page-listing {
	background: #F9F8F6 !important;
}

.program .program-page-listing .page-content__inner {
	max-width: 1280px;
}

.program .program-page-group {
	margin-bottom: 64px;
}

.program .program-page-group__title,
.program .program-page-tours__title {
	font-size: 1.125rem;
	line-height: 1.6;
	letter-spacing: 0.1em;
	text-align: center;
	margin-bottom: 24px;
}

.program .program-page-tours__title:has(span) {
	margin-bottom: 32px;
}

.program .program-page-tours__title span {
	display: block;
	font-size: 0.875rem;
	line-height: 1.5;
	letter-spacing: 0.08em;
}

.program .program-page-group__text {
	font-size: 0.875rem;
	line-height: 2;
	letter-spacing: 0.05em;
	text-align: center;
	margin-bottom: 24px;
}

.program .program-page-group__images {
	display: flex;
	flex-direction: column;
	gap: 16px;
	margin-bottom: 48px;
}

.program .program-page-group__image,
.program .program-page-tours__image {
	display: block;
	width: 100%;
	height: auto;
	aspect-ratio: 4 / 3;
	object-fit: cover;
	background: #d5d5d5;
}

.program .program-page-group__action {
	text-align: center;
}

.program .program-page__reserve-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	overflow: hidden;
	width: 83.71501vw;
	max-width: 420px;
	height: 56px;
	margin: 0 auto;
	background: url(../images/bg-btn.png) no-repeat center / cover;
	border: 1px solid #937946;
	color: var(--color-white);
	font-size: 1rem;
}

.program .program-page-tours {
	margin-bottom: 48px;
}

.program .program-page-tours__list {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	gap: 48px;
}

.program .program-page-tours__item {
	text-align: center;
}

.program .program-page-tours__link {
	display: block;
	text-align: center;
}

.program .program-page-tours__label {
	display: inline-block;
	margin-top: 24px;
	margin-bottom: 12px;
	padding: 6px 8px;
	color: #fff;
	font-size: 0.875rem;
	line-height: 1;
	letter-spacing: 0.05em;
}

.program .program-page-tours__item:nth-child(2) .program-page-tours__label {
	background: #3D5639;
}

.program .program-page-tours__item:nth-child(3) .program-page-tours__label {
	background: #147238;
}

.program .program-page-tours__name {
	margin-top: 0;
	font-size: 1.25rem;
	line-height: 1.5;
	letter-spacing: 0.08em;
}

@media (min-width: 980px) {
	.page-hero__button-link {
		margin: -64px 0 0 auto;
	}
}

.single-program .program-page-content .page-content__inner {
	max-width: 1280px;
}

.single-program .program-entry__hero-content {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	margin-bottom: 28px;
}

.single-program .program-entry__hero-image {
	margin-inline: -1rem;
}

.single-program .program-entry__caption {
	padding: 6px 8px;
	color: #fff;
	font-size: 0.875rem;
	line-height: 1;
	letter-spacing: 0.05em;
	margin-bottom: 16px;
}

.single-program .program-entry__caption span {
	display: inline-block;
	padding: 6px 8px;
}

.single-program .program-entry__title {
	font-size: 1.5rem;
	line-height: 1.5;
	letter-spacing: 0.1em;
}

.single-program .program-entry__sub {
	color: #3D5639;
	font-size: 1rem;
	line-height: 1.7;
	letter-spacing: 0.08em;
}

.single-program .program-entry__body {
	width: 100%;
	line-height: 2;
	letter-spacing: 0.08em;
}

.single-program .program-entry__body > p {
	margin-block: 20px;
	font-size: 0.875rem;
}

.program-entry__table-wrap {
	display: inline-block;
	width: 100%;
	padding-inline: 1rem;
	overflow-x: auto;
	background: #FFF;
}

.single-program .program-entry__table {
	width: 580px;
	background: #fff;
}

.single-program .program-entry__table td {
	position: relative;
	text-align: center;
	border: 0;
}

.single-program .program-entry__table td .program-entry__table-cell-title {
	padding: 16px 20px 8px;
	font-size: 0.75rem;
	line-height: 1.6;
	letter-spacing: 0.06em;
	font-weight: 500;
	vertical-align: middle;
}

.single-program .program-entry__table td .program-entry__table-cell-value {
	padding: 8px 20px 16px;
	font-size: 0.9375rem;
	line-height: 1;
	letter-spacing: 0.06em;
	vertical-align: top;
}

.single-program .program-entry__table td .row {
	display: flex;
	justify-content: center;
}

.single-program .program-entry__table td .row span {
	display: flex;
	flex-direction: column;
	margin-left: -0.75rem;
}

.single-program .program-entry__table td .row span small {
	font-size: 0.6875rem;
	letter-spacing: 0;
}

.single-program .program-entry__table tr:first-child td:last-child {
	padding-top: 12px;
	white-space: nowrap;
	vertical-align: middle;
}

.single-program .program-entry__table td:not(:first-child)::before {
	content: "";
	position: absolute;
	top: calc(50% - 20px);
	left: 0;
	width: 1px;
	height: 40px;
	background: #707070;
}

.single-program .program-entry__lead {
	margin-top: 32px;
}

.single-program .program-entry__lead h2 {
	margin-bottom: 24px;
	font-size: 1.125rem !important;
	text-align: left !important;
}

.single-program .program-entry__lead p {
	font-size: 0.875rem;
	line-height: 1.8;
}

.single-program .program-entry__lead p:last-child {
	margin-bottom: 0;
}

.single-program .program-flow {
	margin-top: 48px;
	max-width: 1280px;
	margin-right: auto;
	margin-left: auto;
}

.single-program .program-flow__header {
	text-align: center;
	margin-bottom: 28px;
}

.single-program .program-flow__title,
.single-program .program-outline__title {
	margin-bottom: 8px;
	text-align: center;
}

.single-program .program-flow__title span,
.single-program .program-outline__title span {
	display: inline-block;
	padding: 6px 12px;
	background: var(--color-gold);
	color: #fff;
	font-size: 0.875rem;
	line-height: 1;
	letter-spacing: 0.05em;
}

.single-program .program-flow__meta {
	font-size: 1rem;
	line-height: 1.7;
	letter-spacing: 0.08em;
}

.single-program .program-flow__inner {
	width: 100vw;
	margin-inline: -1rem;
	overflow-x: visible;
}

.single-program .program-flow__list {
	display: flex;
	gap: 16px;
	padding: 0 1rem 12px;
	overflow-x: auto;
	counter-reset: program-flow-step;
}

.single-program .program-flow__item {
	position: relative;
	flex: 0 0 256px;
	padding: 0 12px 16px;
	background: rgba(255, 255, 255, 0.8);
	counter-increment: program-flow-step;
}

.single-program .program-flow__item.-optional {
	background: rgba(255, 255, 255, 0.8) url(../images/bg-kumiko.png) repeat center top / 69px auto;
}

.single-program .program-flow__item.-optional::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
	width: 100%;
	height: 100%;
	border: 2px solid var(--color-gold);
	pointer-events: none;
}

.single-program .program-flow__no {
	position: absolute;
	left: 6px;
	top: 6px;
	z-index: 2;
	width: 32px;
	height: 32px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 0.875rem;
	line-height: 1.4;
	letter-spacing: 0.06em;
	margin-bottom: 0;
	color: var(--color-white);
	background: linear-gradient(to bottom, #C4B077, #B19B5D);
	border-radius: 50%;
}

.single-program .program-flow__no::before {
	display: block;
	content: counter(program-flow-step);
}

.single-program .program-flow__image-wrap {
	position: relative;
	aspect-ratio: 6 / 5;
	background: #d5d5d5;
	margin: 0 -12px 12px;
	overflow: hidden;
}

.single-program .program-flow__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.single-program .program-flow__optional-label {
	width: fit-content;
	margin-bottom: 4px;
	padding: 2px 6px;
	background: var(--color-gold);
	color: var(--color-white);
	font-size: 0.625rem;
	line-height: 1.4;
	letter-spacing: 0.04em;
}

.single-program .program-flow__item-title {
	font-size: 1rem;
	line-height: 1.6;
	letter-spacing: 0.06em;
	margin-bottom: 8px;
}

.single-program .-optional .program-flow__item-title {
	color: #937946 !important;
}

.single-program .program-flow__text {
	font-size: 0.875rem;
	line-height: 1.8;
	letter-spacing: 0.05em;
}

.single-program .program-flow__desc {
	font-size: 0.8125rem;
	line-height: 1.8;
	letter-spacing: 0.04em;
	margin-top: 10px;
	padding-top: 12px;
	border-top: 1px solid #D1D1C5;
}

.single-program .program-outline {
	margin-top: 56px;
	max-width: 1280px;
	margin-right: auto;
	margin-left: auto;
}

.single-program .program-outline__summary {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 8px;
	margin-top: 32px;
	padding-bottom: 12px;
	border-bottom: 1px solid #9A8C7C;
}

.single-program .program-outline__name {
	font-size: 1.25rem;
	line-height: 1.5;
	letter-spacing: 0.08em;
}

.single-program .program-outline__price {
	margin-top: 24px;
	padding-top: 20px;
	padding-bottom: 20px;
	border-top: 1px solid #9A8C7C;
	border-bottom: 1px solid #9A8C7C;
}

.single-program .program-outline__price-main {
	font-size: 1rem;
	line-height: 1.8;
	letter-spacing: 0.06em;
}

.single-program .program-outline__price-amount {
	margin-right: 4px;
	font-size: 1.375rem;
	line-height: 1.5;
	letter-spacing: 0.04em;
}

.single-program .program-outline__price-meta {
	font-size: 0.875rem;
	line-height: 1.5;
	letter-spacing: 0.08em;
}

.single-program .program-outline__price-note {
	font-size: 0.9375rem;
}

.single-program .program-outline__price-option {
	display: inline-block;
	margin-top: 0.25em;
	font-size: 0.9375rem;
	line-height: 1.8;
	letter-spacing: 0.06em;
}

.single-program .program-outline__note {
	margin-top: 8px;
	font-size: 0.8125rem;
	line-height: 1.8;
	letter-spacing: 0.06em;
}

.single-program .program-outline__awards {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 16px;
	background: rgba(255, 255, 255, 0.5);
	margin-top: 40px;
	padding: 20px;
}

.single-program .program-outline__awards-badge {
	width: 80px;
	height: 85px;
	margin-inline: auto;
	flex-shrink: 0;
	background: url(../images/img-awards.png) no-repeat center / contain;
	font-size: 0;
}

.single-program .program-outline__awards-text {
	font-size: 0.875rem;
	line-height: 1.8;
	letter-spacing: 0.05em;
}

.single-program .program-benefits,
.single-program .program-reccomended {
	margin-top: 64px;
	max-width: 1280px;
	margin-right: auto;
	margin-left: auto;
}

.single-program .program-benefits__title,
.single-program .program-reccomended__title {
	margin-bottom: 1.5rem;
	padding-bottom: 0.25em;
	border-bottom: 1px solid #D1D1C5;
	font-size: 1.125rem;
	line-height: 1.6;
	text-align: center;
}

.single-program .program-benefits__list {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 32px 24px;
}

.single-program .program-benefits__item-title {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 45px;
	margin-bottom: 8px;
	font-size: 0.875rem;
	line-height: 1.5;
	letter-spacing: 0.06em;
	text-align: center;
}

.single-program .program-benefits__image {
	aspect-ratio: 4 / 3;
	background: #d5d5d5;
	margin-bottom: 12px;
	overflow: hidden;
}

.single-program .program-benefits__image img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.single-program .program-benefits__text {
	font-size: 0.8125rem;
	line-height: 1.5;
	letter-spacing: 0.05em;
}

.single-program .program-reccomended__list,
.single-program .program-reccomended__content {
	margin-top: 24px;
	margin-left: 1em;
}

.single-program .program-reccomended__item,
.single-program .program-reccomended__content li {
	font-size: 0.875rem;
	line-height: 1.5;
	letter-spacing: 0.06em;
}

.single-program .program-reccomended__item::before,
.single-program .program-reccomended__content li::before {
	color: var(--color-gold);
	content: '●';
}

.single-program .program-reccomended__content ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

.single-program .program-reccomended__content p {
	font-size: 0.875rem;
	line-height: 1.5;
	letter-spacing: 0.06em;
}

.single-program .program-reccomended__image {
	display: flex;
	flex-direction: column;
	gap: 24px;
	margin-top: 2rem;
}

.single-program .program-message {
	margin-top: 48px;
}

.single-program .program-message__text {
	font-size: 0.875rem;
	line-height: 1.8;
	letter-spacing: 0.05em;
	text-align: center;
}

.single-program .program-message__image {
	display: flex;
	flex-direction: column;
	gap: 24px;
	margin-top: 2rem;
}

.single-program .program-message__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.program-message + .exp-menu {
	padding-top: 5rem;
	background: transparent;
}

.exp-menu__item-text {
	margin-bottom: 1rem;
}

.contact-btn {
	text-decoration: underline;
}

@media (min-width: 644px) {
	.program-entry__table-wrap {
		width: fit-content;
	}
}

@media (min-width: 768px) {
	.program .program-page-tours__title:has(span) {
		margin-bottom: 48px;
	}

	.program .program-page-group__title,
	.program .program-page-tours__title {
		font-size: 1.375rem;
		margin-bottom: 32px;
	}

	.program .program-page-group__text {
		font-size: 1rem;
		margin-bottom: 32px;
	}

	.program .program-page-group__images {
		flex-direction: row;
		gap: 24px;
		max-width: 950px;
		margin: 0 auto 64px;
	}

	.program .program-page-group__image {
		width: calc(50% - 12px);
	}

	.program .program-page-tours__list {
		grid-template-columns: repeat(3, minmax(0, 1fr));
		gap: 24px;
	}

	.program .program-page-tours__name {
		font-size: 1.375rem;
	}

	.single-program .program-benefits__item-title {
		font-size: 1rem;
	}
}

@media (min-width: 768px) {
	.single-program .program-page-content .page-content__inner {
		width: calc(100% - 2 * 5vw);
	}

	.single-program .program-entry__hero-image {
		margin: 3rem 0 0;
	}
}

@media (min-width: 980px) {
	.single-program .program-entry__title {
		font-size: 2rem;
	}

	.single-program .program-entry__sub {
		font-size: 1.25rem;
	}

	.single-program .program-entry__body {
		font-size: 1rem;
	}

	.single-program .program-entry__lead h2 {
		margin-bottom: 2rem;
    font-size: 1.375rem !important;
    line-height: 1.72;
	}

	.single-program .program-flow {
		margin-top: 64px;
	}

	.single-program .program-flow__inner {
		margin-inline: -5vw;
	}

	.single-program .program-flow__list {
		padding: 0 5vw 24px;
	}

	.single-program .program-outline {
		max-width: 780px;
		margin: 72px auto 0;
	}

	.single-program .program-outline__summary {
		flex-direction: row;
		align-items: center;
		justify-content: space-between;
		gap: 20px;
	}

	.single-program .program-outline__awards {
		flex-direction: row;
		align-items: center;
		gap: 24px;
		padding: 28px;
	}

	.single-program .program-outline__awards-badge {
		width: 90px;
		height: 96px;
		margin-inline: 0;
	}

	.single-program .program-benefits {
		margin-top: 80px;
	}

	.single-program .program-benefits__title {
		font-size: 1.25rem;
	}

	.single-program .program-benefits__list {
		grid-template-columns: repeat(4, minmax(0, 1fr));
		gap: 20px;
	}

	.single-program .program-benefits__item-title {
		font-size: 0.9375rem;
	}

	.single-program .program-reccomended {
		display: flex;
		flex-wrap: wrap;
	}

	.single-program .program-reccomended__title {
		width: 100%;
	}

	.single-program .program-reccomended__image {
		flex-direction: row;
		max-width: calc(100% - 260px);
		margin-top: 24px;
		margin-left: auto;
	}

	.single-program .program-reccomended__image img {
		width: calc(50% - 12px);
	}

	.single-program .program-message {
		margin-top: 5rem;
	}

	.single-program .program-message__image {
		display: flex;
		flex-direction: row;
		gap: 24px;
	}

	.single-program .program-message__image img {
		width: calc(50% - 12px);
	}

	.exp-menu__item-text br:first-child {
		display: none;
	}

	.single-program .exp-menu__item {
		width: auto;
	}

	.program-message + .exp-menu {
		padding-bottom: 0;
	}
}

@media (min-width: 1024px) {
	.program .program-page-tours__title:has(span) {
		margin-bottom: 64px;
	}
	
	.single-program .page-content {
		padding-top: 184px !important;
	}

	.single-program .program-entry__hero {
		display: flex;
		gap: 5%;
		margin-bottom: 64px;
	}

	.single-program .program-entry__hero-image {
		margin-top: 0;
	}

	.single-program .program-entry__lead {
		max-width: 950px;
		margin-inline: auto;
	}

	.single-program .program-flow__inner {
		width: 100%;
		margin-inline: 0;
	}
	
	.single-program .program-flow__list {
		display: grid;
		grid-template-columns: repeat(5, minmax(0, 1fr));
		gap: 20px;
		overflow-x: visible;
		padding: 0;
	}

	.single-program .program-flow__item {
		flex: none;
	}

	.single-program .program-benefits,
	.single-program .program-reccomended,
	.single-program .program-message {
		max-width: 950px;
		margin-inline: auto;
	}
}

@media (min-width: 1280px) {
	.single-program .page-content {
		padding-top: 204px !important;
	}
}
