.timetable{
	display:flex;
	align-items:stretch;
	width:100%;
	max-width:100%;
	box-sizing:border-box
}
.timetable *{
	box-sizing:inherit
}
.timetable li,.timetable ul{
	list-style-type:none;
	margin:0
}
.timetable li,.timetable ul{
	padding:0
}
.timetable>aside{
	flex:none;
	max-width:30%;
	padding:0!important;
	margin-top:46px;
	border-right:5px solid transparent;
	position:relative
}
.timetable>aside li{
	padding:0 15px;
	background-color:#efefef;
	line-height:46px
}
.timetable>aside li:not(:last-of-type){
	border-bottom:1px solid #fff
}
.timetable>aside .row-heading{
	color: black; 
	display:inline-block;
	max-width:100%;
	overflow:hidden;
	text-overflow:ellipsis;
	white-space:nowrap;
	word-wrap:normal
}
.timetable>aside:before{
	content:"";
	display:block;
	background-color:#fff;
	height:46px;
	position:relative;
	margin-top:-46px;
	top:0
}
.timetable aside li,.timetable time li{
	height:46px
}
.timetable>section{
	flex:3 0 auto;
	width:0;
	padding:0!important
}
.timetable>section time{
	display:block;
	width:100%;
	overflow-x:scroll;
	-webkit-overflow-scrolling:touch
}
.timetable>section>header{
	position:relative;
	top:0;
	z-index:3;
	width:100%;
	overflow:hidden;
	background-color:#fff;
	transform-style:preserve-3d
}
.timetable>section>header ul{
	display:flex;
	height:46px;
	align-items:center
}
.timetable>section>header li{
	flex:none;
	display:block;
	position:relative;
	width:96px
}
.timetable>section>header li .time-label{
	color:black;
	display:block;
	position:absolute;
	left:0
}
.timetable>section>header li:not(:first-of-type) .time-label{
	transform:translateX(-50%)
}
.timetable>section>header li:last-of-type{
	width:0
}
.timetable>section>header li:last-of-type .time-label{
	transform:translateX(-100%)
}
.timetable ul.room-timeline{
	border-left:none;
	display:flex;
	flex-direction:column;
	align-items:stretch
}
.timetable ul.room-timeline li{
	position:relative;
	background-color:#4D4D4D;
	height:46px
}
.timetable ul.room-timeline li:nth-of-type(odd){
	background-color:#303030;
}
.timetable ul.room-timeline li:first-of-type{
	border-top:1px solid #ADADAD
}
.timetable ul.room-timeline li:last-of-type{
	border-bottom:1px solid #ADADAD
}
.timetable ul.room-timeline li:not(:last-of-type){
	border-bottom:none
}
.timetable ul.room-timeline li:first-child .time-entry{
	height:44px
}
.timetable ul.room-timeline li:after,.timetable ul.room-timeline li:before{
	content:"";
	position:absolute;
	z-index:1;
	left:0;
	top:0;
	right:0;
	bottom:0
}
.timetable ul.room-timeline li:before{
	background-image:linear-gradient(90deg,#e5e5e5 1px,transparent 0);
	background-size:24px auto
}
.timetable ul.room-timeline li:after{
	background-image:linear-gradient(90deg,#e5e5e5,#e5e5e5 1px,#f4f4f4 0,#f4f4f4 2px,#e5e5e5 0,#e5e5e5 3px,transparent 0,transparent);
	background-size:96px auto;
	background-position:-2px 0
}
.timetable .time-entry {
	background-color:#1c6a5e;
	transition:background-color .2s;
	height:45px;
	display:block;
	position:absolute;
	z-index:2;
	padding:0 10px;
	white-space:normal;
	overflow:hidden;
	color:#fff;
	border:1px solid #e32c1b;
	transform-style:preserve-3d
}


.timetable .time-entry
.timetable .time-entry small{
	position:relative;
	top:50%;
	transform:translateY(-50%);
	display:block
}
.timetable .time-entry:hover{
	background-color:#e74030
}
