@charset "utf-8";

body,
div,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
pre,
form,
fieldset,
input,
textarea,
p,
blockquote header footer section {
	margin: 0;
	padding: 0;
	color: #666666;
	-webkit-text-size-adjust: 100%;
	-webkit-padding-start: 0px;
	text-align: center;
	vertical-align: baseline;
	font-size: 14px;
	font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", YuGothic, "Yu Gothic Medium",
		"Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
	line-height: 1.5;
}
input {
	color: #666666;
}
select {
	color: #666666;
}
img {
	border-style: none;
	border: 0;
	vertical-align: middle;
}
a {
	text-decoration: none;
	color: #666666;
}
li {
	list-style-type: none;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}
.clearfix {
	clear: both;
}
.clearfix:after {
	content: "";
	display: block;
	clear: both;
}
section {
	margin-bottom: 32px;
}
.sohbungreen {
	color: #00a59f;
}
.sohbunlime {
	color: #8ec43e;
}
.red {
	color: #ff6666;
}
.trans a:hover {
	opacity: 0.5;
}
/*--------------------------------------------------------------------------------------------------*/
.pc_only {
	display: inline;
}
.sp_only {
	display: none;
}
@media screen and (max-width: 440px) {
	.pc_only {
		display: none;
	}
	.sp_only {
		display: inline;
	}
}
.img_pc_only {
	display: block;
}
.img_sp_only {
	display: none;
}
@media screen and (max-width: 960px) {
	.img_pc_only {
		display: none;
	}
	.img_sp_only {
		display: block;
	}
}
h1 {
	font-size: 28px;
	padding: 80px 0 40px;
	text-align: left;
	font-weight: 200;
	
}
h1 span {
	font-size: 56px;
}
@media screen and (max-width: 440px) {
	h1 {
		font-size: 24px;
	}
}
h1 img {
	width: 100%;
	height: auto;
	margin: 0 auto 32px;
}
main {
	max-width: 920px;
	margin: 0 auto;
	box-sizing: border-box;
	padding: 0 16px;
}
@media screen and (max-width: 440px) {
	html,
	main {
		min-width: 440px;
	}
}
.about {
	text-align: center;
	font-size: 18px;
	line-height: 1.8;
	margin-bottom: 32px;
}
.about a {
	color: #00a59f;
}
.about a:hover {
	text-decoration: underline;
}

.jtb a {
	color: #00a59f;
}
.jtb a:hover {
	text-decoration: underline;
}
.bnr_jtb {
	margin-bottom: 16px;
}
@media screen and (max-width: 490px) {
	.bnr_jtb {
		width: 94%;
		height: auto;
	}
}

h2 {
	font-size: 16px;
	font-weight: normal;
	color: #00a59f;
	border-top: solid 1px #00a59f;
	border-bottom: solid 1px #00a59f;
	padding: 8px 0 8px;
	text-align: left;
	margin-bottom: 16px;
}
h3 {
	font-size: 16px;
	font-weight: normal;
	color: #00a59f;
	text-align: left;
	margin-bottom: 16px;
}

/*---------------------------------------------------------------------------*/
.table_main_hotel {
	max-width: 100%;
	margin-bottom: 8px;
	width: 100%;
	box-sizing: border-box;
}
.table_main_hotel th {
	vertical-align: top;
	font-weight: normal;
	padding: 16px;
	border: solid 1px #666666;
	background-color: #eeeeee;
	max-width: 288px;
	box-sizing: border-box;
}
.table_main_hotel td {
	font-weight: normal;
	padding: 16px;
	border: solid 1px #666666;
}
.table_main_hotel td:first-child a {
	color: #00a59f;
}
.table_main_hotel td:first-child a:hover {
	text-decoration: underline;
}
/*-------------------------------------------*/
@media screen and (max-width: 440px) {
	.table_main_hotel .thead {
		display: none;
	}
	.table_main_hotel tr {
		max-width: 408px;
	}
	.table_main_hotel td {
		display: block;
		text-align: right;
		max-width: 408px;
	}
	.table_main_hotel td {
		border-bottom: none;
	}
	.table_main_hotel td:last-child {
		border-bottom: solid 1px #666666;
	}
	.table_main_hotel td:first-child {
		background: #eeeeee;
		text-align: center;
		margin-top: 16px;
	}
	.table_main_hotel td:before {
		content: attr(data-label);
		float: left;
		margin-right: 10px;
	}
	.table_main_hotel tr {
		margin-top: 16px;
	}
}
/*---------------------------------------------------------------------------*/
.table_cancel {
	margin-bottom: 16px;
	width: 100%;
}
.table_cancel th {
	vertical-align: top;
	font-weight: normal;
	padding: 8px;
	border: solid 1px #666666;
	background-color: #eeeeee;
	max-width: 288px;
	box-sizing: border-box;
}
.table_cancel td {
	font-weight: normal;
	padding: 8px;
	border: solid 1px #666666;
}

.table_main_payment {
	max-width: 100%;
	margin-bottom: 32px;
	width: 100%;
	text-align: left;
}
.table_main_payment tr {
	vertical-align: top;
	font-weight: normal;
}
.table_main_payment th {
	font-weight: normal;
	width: 32px;
	padding-bottom: 16px;
}
.table_main_payment td {
	font-weight: normal;
	padding-bottom: 16px;
}
.btn_red a {
	display: inline-block;
	color: #fff;
	font-size: 24px;
	line-height: 2;
	margin: 32px auto 4px;
	background-color: #ff6666;
	border-radius: 32px;
	width: 384px;
	height: 48px;
	box-sizing: border-box;
}
.btn_red a:hover {
	opacity: 0.5;
}
/*--------------------------------------------------------------------------------------------------*/
form {
	position: relative;
}
.table_form {
	max-width: 100%;
	margin-bottom: 16px;
	width: 100%;
	text-align: left;
}
.table_form th {
	vertical-align: top;
	text-align: left;
	font-weight: normal;
	padding: 16px;
	border: solid 1px #666666;
	background-color: #eeeeee;
	width: 256px;
	box-sizing: border-box;
}
.table_form td {
	font-weight: normal;
	padding: 16px;
	border: solid 1px #666666;
	position: relative;
}
.table_form td input {
	text-align: left;
}
.table_form td input[type="text"],
.table_form td input[type="email"],
.table_form td input[type="tel"] {
	padding-left: 5px;
	padding-right: 5px;
}
.table_form td textarea {
	padding-left: 5px;
	padding-right: 5px;
}

.table_form .unit {
	display: flex;
	gap: 10px 20px;
	flex-wrap: wrap;
}

div:has(input[name="radio_1_text"]),
div:has(input[name="radio_2_text"]),
div:has(input[name="radio_3_text"]) {
	flex-grow: 1;
	display: flex;
	align-items: center;
}
input[name="radio_1_text"],
input[name="radio_2_text"],
input[name="radio_3_text"] {
	flex-grow: 1;
	margin-left: 10px;
}

.table_form .unit > input {
	flex-grow: 1;
}
.table_form .unit.-s {
	gap: 10px 10px;
}
.table_form .unit + .unit {
	margin-top: 10px;
}

.table_form .unit.days {
	gap: 10px 5px;
	align-items: center;
}

.table_form .unit.sb {
	justify-content: space-between;
}
.table_form .unit.name .box {
	justify-content: space-between;
	position: relative;
}
.table_form .unit.name p {
	white-space: nowrap;
}

.table_form .unit.name input {
	width: 90%;
}
.table_form .unit .box {
	width: calc(50% - 10px);
	display: flex;
	align-items: center;
	gap: 0 5px;
	position: relative;
}
.table_form .unit.-s .box {
	width: fit-content;
}

.pc-inline {
	display: inline-block;
}

.uchiwake {
	display: flex;
	gap: 0 10px;
}

.uchiwake_nationality {
	display: block;
	text-align: left;
	text-indent: -1em;
	margin-left: 1em;
	margin-right: -10px;
	width: 100%;
}

.full-width-input {
	text-align: left;
	margin-left: -1em;
	min-width: calc(100% - 10px);
}

.box-submit {
	padding-bottom: 50px;
}
@media screen and (max-width: 768px) {
	.pc-inline {
		display: none;
	}
	.member {
		justify-content: space-between;
		justify-content: flex-start;

	}
	.uchiwake {
		display: flex;
		flex-direction: column;
		gap: 10px;
		align-items: flex-end;
	}
}
.table_form .unit .date {
	width: fit-content;
}
.table_form .unit .box input {
}
.pl {
	padding: 0.5em 0 0.5em 1em;
	text-align: left;
}
select {
	padding: 3px;
}
@media screen and (max-width: 440px) {
	.table_form th {
		display: block;
		width: 408px;
	}
	.table_form td {
		display: block;
		max-width: 408px;
		margin-bottom: 16px;
		margin-top: -1px;
	}
}
/*----------------*/
.mf {
	min-width: calc(100% - 11px);
}
.large {
	width: calc(100% - 8em);
}
textarea {
	text-align: left;
	resize: none;
	min-width: calc(100% - 10px);
	min-height: 100px;
}
@media screen and (max-width: 440px) {
	.notice_form3 {
		margin-top: -16px;
	}
}
.agree {
	display: flex;
	justify-content: center;
	margin-top: 2em;
	align-items: center;
}
.submit input {
	margin-top: 16px;
	width: 170px !important;
	font-size: 18px;
	font-weight: 500;
	text-align: center;
	color: #fff;
	background-color: #00a59f;
	padding: 5px 10px 6px 10px;
	border-radius: 20px;
	cursor: pointer;
	border-style: none;
}
.submit input:hover {
	opacity: 0.5;
}
/*--------------------------------------------------------------------------------------------------*/
.notice {
	text-align: left;
	padding-bottom: 12px;
}
.notice_main {
	font: 14px;
	text-align: left;
	text-indent: -0.7em;
	padding-left: 0.7em;
	padding-bottom: 12px;
}
.notice_form {
	font: 14px;
	text-align: left;
	text-indent: -1em;
	padding-left: 1em;
	padding-bottom: 4px;
}

/*--------------------------------------------------------------------------------------------------*/
footer {
	background-color: #eeeeee;
}
.footer_wrap {
	max-width: 920px;
	margin: 0 auto;
	box-sizing: border-box;
	padding: 32px 16px;
	font: 200 14px 'Noto Sans JP', sans-serif;

}
.footer_wrap table {
	text-align: left;
	line-height: 1.5;
}
.footer_wrap table th {
	width: 104px;
	vertical-align: top;
	font-weight: normal;
}
.footer_wrap table td {
	padding-bottom: 16px;
	font-weight: normal;
}
.footer_wrap table td a:hover {
	text-decoration: underline;
}
@media screen and (max-width: 440px) {
	.footer_wrap {
		max-width: 408px;
		padding-left: 0;
	}
}

.confirm td p {
	text-align: left;
	display: inline-block;
	word-break: break-all;
}

/*--------------------------------------------------------------------------------------------------*/

.thanks {
	margin: 300px auto;
}
.thanks p {
	font-size: 20px;
	padding-bottom: 20px;
}
.thanks p a:hover {
	text-decoration: underline;
}
.close {
	margin: 300px auto;
	font-size: 22px;
}
/*--------------------------------------------------------------------------------------------------*/

::placeholder {
	color: #949494;
}

.btn {
	display: inline-block;
	margin-left: 10px;
	background-color: #00a59f;
	padding: 5px 10px;
	border-radius: 5px;
	color: #fff;
	transition: all 0.3s;
}
@media (any-hover: hover) {
	.btn:hover {
		opacity: 0.7;
	}
}
.footer_logo img {
	width: 128px;
	height: auto;
	margin-right: auto;
	display: block;
}