/**
 * t-timepicker.css
 */

/* 時間入力フォームのスタイル */
.t-timepicker {
	position: relative;
	display: inline-flex;
	font-size: 14px;
	vertical-align: top;
	cursor: pointer;
}

.t-timepicker .t-timepicker__view {
	padding: 4px 6px;
	border: 1px solid #cccccc;
	border-radius: 4px 0 0 4px;
	background-color: #EEEEEE;
	margin-bottom: 0;
	font-size: 1em;
	height: 20px;
	/*min-width: 5em;*/
	/*max-width: 5em;*/
	width: 5em;
}

.t-timepicker .t-timepicker__btn {
	padding: 4px 6px;
	background-color: #EEEEEE;
	border: 1px solid #cccccc;
	border-radius: 0 4px 4px 0;
	text-decoration: none;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #333333;
	font-size: 1em;
}

.t-timepicker .t-timepicker__btn:hover {
	background-color: #DEDEDE;
	text-decoration: none;
	color: #333333;
}

/* disabled */
.t-timepicker.disabled,
.t-timepicker.disabled .t-timepicker__view {
	cursor: not-allowed;
}

.t-timepicker.disabled :is(.t-timepicker__view, .t-timepicker__btn) {
	pointer-events: none;
}

/* モーダルのオーバーレイ */
.t-timepicker-modal-overlay {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: transparent;
	z-index: 1060; /* Bootstrapモーダル(1050)より高く設定 */
	display: none;
}

.t-timepicker-modal-overlay.show {
	display: block;
}

/* モーダル本体 */
.t-timepicker-modal {
	position: absolute;
	background-color: #fff;
	border-radius: 4px;
	box-shadow: 0 5px 15px rgba(0, 0, 0, 0.3);
	z-index: 1061; /* Bootstrapモーダル(1050)より高く設定 */
	min-width: 200px;
	padding: 15px;
	display: none;
	margin-top: 8px;
}

.t-timepicker-modal.show {
	display: block;
}

/* モーダルの矢印（上向き三角形） */
.t-timepicker-modal::before {
	content: '';
	position: absolute;
	top: -8px;
	left: 20px;
	width: 0;
	height: 0;
	border-left: 8px solid transparent;
	border-right: 8px solid transparent;
	border-bottom: 8px solid #fff;
	filter: drop-shadow(0 -2px 2px rgba(0, 0, 0, 0.1));
}

/* モーダルボディ */
.t-timepicker-modal__body {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 5px;
}

/* 横並びフォーム */
.t-timepicker-modal__form-inline {
	display: flex;
	align-items: center;
}

/* 区切り文字 */
.t-timepicker-modal__separator {
	font-size: 1em;
	font-weight: bold;
	padding: 0;
	color: #333;
}

/* 入力ラッパー */
.t-timepicker-modal__input-wrapper {
	display: flex;
	flex-direction: column;
	align-items: stretch;
}

.t-timepicker-modal__form-inline .t-timepicker-modal__label {
	font-weight: bold;
	font-size: 1em;
	white-space: nowrap;
}

.t-timepicker-modal__form-inline .t-timepicker-modal__input {
	width: 3em;
	padding: 6px 8px;
	font-size: 1em;
	border: 1px solid #ccc;
	border-radius: 0;
	margin: 0;
	text-align: center;
	flex: 1;
}

/* input[type="number"]のスピナーを非表示 */
.t-timepicker-modal__input::-webkit-outer-spin-button,
.t-timepicker-modal__input::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

.t-timepicker-modal__input[type="number"] {
	-moz-appearance: textfield;
}

.t-timepicker-modal__input:focus {
	outline: none;
	border-color: #66afe9;
	box-shadow: 0 0 8px rgba(102, 175, 233, 0.6);
}

/* 矢印ボタン */
.t-timepicker-modal__arrow {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 2em;
	padding: 0;
	margin: 0;
	cursor: pointer;
	font-size: 0.8em;
	color: #333333;
	flex: 0 0 auto;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
	-webkit-tap-highlight-color: transparent;
	touch-action: manipulation;
}

.t-timepicker-modal__arrow:hover {
	background-color: #e6e6e6;
	text-decoration: none;
	color: #333333;
}

.t-timepicker-modal__arrow:active {
	background-color: #d4d4d4;
}

.t-timepicker-modal__arrow-up {
	border-radius: 4px 4px 0 0;
}

.t-timepicker-modal__arrow-down {
	border-radius: 0 0 4px 4px;
}
