
/*  encoding
========================================================================== */
@charset "utf-8";


/*  style
========================================================================== */
* {
	outline: none !important;
}

.lang {
  height: 100%;
}.lang.ja {
  font-family: "Hiragino Kaku Gothic ProN",Meiryo,"メイリオ","ＭＳ Ｐゴシック",sans-serif;
}.lang.zh-cn {
  font-family: "Microsoft YaHei","微软雅黑","SimSun",sans-serif;
}.lang.zh-tw {
  font-family: "Microsoft JhengHei","微軟正黑體","PMingLiU",sans-serif;
}.lang.ko {
  font-family: "Malgun Gothic","Yoon Gothic",sans-serif;
}.lang.unicode {
  font-family: Meiryo,"arial unicode ms",sans-serif;
}

h2.pagetitle {
	line-height: 2.5rem;
}

h2.pagetitle span {
	display: block;
	width: 100%;
	font-size: 1.5rem;
}

textarea {
	display: block;
}

.tb-form input[type="time"] {
	cursor: pointer;
	position: relative;
	width: auto;
	text-align: center;
	padding-left: 1.5rem;
	padding-right: 1.5rem;
}

.tb-form input[type="time"]::-webkit-calendar-picker-indicator {
	cursor: pointer;
  opacity: 0;
	position: absolute;
  width: 100%;
  height: 100%;
}

.contact-mail {
	width: 250px;
	padding: 0.5em 0.8em;
	color: #fff;
	margin: 10px;
}

.contact-mail:hover {
	color: #fff;
	text-decoration: none;
}

.grecaptcha-badge {
	bottom: 100px !important;
}

.tb-form {
	margin: 0 auto;
	max-width: none;
	width: 95%;
}

.title span.ruby {
	font-size: 1em;
	margin: 0 1em;
	width: 100%;
}

::placeholder {
	color: #ccc;
}

/* 旧Edge対応 */
::-ms-input-placeholder {
	color: #ccc;
}

/* IE対応 */
:-ms-input-placeholder {
	color: #ccc;
}

.title {
	padding-bottom: 8px;
	background: none;
	color: #0f1a4a;
}

.required,
.optional {
	position: unset;
	padding: 0px 30px;
}

form#apply-form > table td.warning p.warning-msg {
	font-size: 0.875rem;
}

.tb-form tr.sub-form.hidden {
	display: none;
}

.tb-form tbody tr td {
	vertical-align: middle;
}

.tb-form tbody tr th.whname label.title span:nth-child(1) {
	font-size: 1rem;
	font-weight: bold;
	line-height: 1.5rem;
	margin-bottom: .125rem;
}

.tb-form tbody tr th.whname label.title span:nth-child(2) {
	display: inline-block;
	width: 100%;
	font-size: .875rem;
	font-weight: normal;
	line-height: 1.25rem;
}

.sp-pt-table {
	width: 100%;
	margin-bottom: 8px;
}

.sp-pt-table tbody tr th {
	font-size: 0.875rem;
	font-weight: normal;
	border: none;
}

.sp-pt-table tbody tr:last-child td {
	border-bottom: 1px solid #ddd;
}

.sp-pt-table tbody tr td:nth-child(1) {
	width: 45%;
}

.sp-pt-table tbody tr td:nth-child(2) {
	width: 45%;
}

.sp-pt-table tbody tr td:nth-child(3) {
	width: 10%;
	min-width: 40px;
	text-align: center;
	vertical-align: middle;
}

.sp-pt-table tbody tr td:nth-child(3) button,
.sp-pt-table + button {
	position: relative;
	width: 40px;
	height: 40px;
}

.sp-pt-table tbody tr td:nth-child(3) button i,
.sp-pt-table + button i {
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
	width: 22px;
	height: 16px;
	margin: auto;
}

.sp-pt-table tbody tr td:nth-child(3) button:hover,
.sp-pt-table + button:hover {
	color: #999;
	border-bottom: 1px solid #bbb;
}

.sp-pl-list {
	width: 100%;
	list-style: none;
}

.sp-pl-list li {
	position: relative;
	width: 100%;
	margin: 1rem 0;
	padding-left: calc(22px + 0.5rem) !important;
}

.sp-pl-list li input[type="radio"] {
	cursor: pointer;
	position: absolute;
	top: 1px;
	left: 0;
	width: 22px;
	height: 22px;
	margin: 0;
	padding: 0;
	border-radius: 50%;
}

.sp-pl-list li input[type="radio"]:checked::before {
	transform: scale(1);
}

.sp-pl-list li input[type="radio"]::before {
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
	content: "";
	display: inline-block;
	width: 12px;
	height: 12px;
	margin: auto;
	border-radius: 50%;
	background-color: #444;
	transform: scale(0);
}

.sp-pl-list li label {
	font-size: 1rem;
	font-weight: bold;
}
.sp-pl-list li label span {
	display: block;
}
.sp-pl-list li label span:nth-child(2) {
	font-size: 0.875rem;
	font-weight: normal;
}

.sp-pl-list li label + p {
	font-size: 0.875rem;
	margin-top: 0.75rem;
	text-indent: -1rem;
}

.sp-pl-list li label + p.sub-form {
	display: block;
	text-indent: 0;
}

.sp-pl-list li label + p.hidden {
	display: none;
}

.sp-pl-list li label + p label {
	font-size: 0.875rem;
}

.sp-pl-list li label + p input {
	margin-top: 0.75rem;
}

@media screen and (max-width: 768px) {
	.required, .optional {
		margin-bottom: 8px;
	}
	.sp-pt-table tbody tr td {
		display: table-cell;
		width: inherit;
	}
}

.datepicker.active {
	text-decoration: none !important;
}