.time_input {
	--input-width: 110pt;
	--button-width: 20px;
	--input-height: 24px;

	display: inline-block;
	position: relative;

	width: var(--input-width);
	height: var(--input-height);
	margin: 10pt 6pt;

	white-space: nowrap;
}

.time_input > input {
	display: inline-block;
	vertical-align: top;	

	width: calc(var(--input-width) - var(--button-width) - 3pt - 5pt);
	height: calc(var(--input-height) - 1px - 2*3pt);
	padding: 3pt;
	padding-right: calc(5pt + var(--button-width));
	
	border: 0;
	border-bottom: 1px solid #CCC;

	font-family: Consolas;
	font-size: 14px;
	text-align: right;

	background: transparent;
}

.time_input > .buttons {
	display: inline-block;
	position: absolute;
	right: 0;

	width: var(--button-width);
}

.time_input > .buttons > .button {
	width: var(--button-width);
	height: calc(var(--input-height)/2 - 1px);

	border: 0;
	border-bottom: 1px solid #CCC;

	background-color: #EEE;
	background-size: calc(var(--input-height)/2);
	background-repeat: no-repeat;
	background-position: center;
}

.time_input > .buttons > .button:hover {
	background-color: #CCC;
}

.time_input > .buttons > .button.up {
	background-image: url("icons/remixicon/arrow-up-s-line.svg");
}

.time_input > .buttons > .button.down {
	background-image: url("icons/remixicon/arrow-down-s-line.svg");
}
