* {
	margin: 0;
	padding: 0;
}

body {
    background-color: #EAEAEA;

	font-family: "Avenir Next", 'Exo', sans-serif;
	
	font-size: 16pt;
	color: black;
}
.page {
    background-color: white;
}

.name {
	font-weight: bold;
}

div#banner, div#harbour, div#hall-back, div#rocks, div#pebbles, div#sunny-sands {
	width:100%;
	overflow: hidden;
	object-fit: cover;
	background-position: center center;
  	background-repeat: no-repeat;
  	background-size: cover;
}

div#banner {
	height:680px;
  	background-image: url('assets/banner.jpg');
  }
div#harbour {
	height:250px;
  	background-image: url('assets/harbour.jpg');
  	margin-top: 2em;
  	/*margin-bottom: 1em;*/
}
div#hall-back {
	height:250px;
  	background-image: url('assets/leas-cliff-hall-back.jpg');
  	margin-top: 1em;
  	margin-bottom: 1em;
}
div#rocks {
	height:250px;
  	background-image: url('assets/rocks.jpg');
  	margin-top: 2em;
  	margin-bottom: 1em;
  	background-position: center bottom; 
}
div#pebbles {
	height:250px;
  	background-image: url('assets/pebbles.jpg');
  	margin-top: 2em;
  	/*margin-bottom: 1em;*/
}
div#sunny-sands {
	height:250px;
  	background-image: url('assets/sunny-sands.jpg');
  	margin-top: 2em;
  	margin-bottom: 1em;
}


img#logo {
	z-index: 100;
	position: relative;
	top: 32px;
	text-align: center;
	display: block;
	width:250px;

	margin-left: auto;
	margin-right: auto;
}

#subtitle {
	z-index: 100;
	position: relative;
	top: 100px;
	text-align: center;

	font-family: 'Montserrat', "Avenir Next", sans-serif;
	
	font-size: 44px;

	color: white;
}
#dates {

	z-index: 100;
	position: relative;
	top: 180px;
	text-align: center;

	font-family: 'Montserrat', "Avenir Next", sans-serif;

	font-size: 44px;

	color: yellow;
}

div.menu {
	position:sticky;
	position: -webkit-sticky;
	top:0px;
	z-index: 99;

	opacity: 0.9;
	background-color: #17173C;
	box-shadow: 4px 4px 12px rgba(0,0,0,0.30);
	color: white;

	display:flex;
	flex-direction: row;
	justify-content: center;
}
div.menu-with-logo {
	justify-content: space-between;	
}
.menu p {
	padding-left:1em;
	padding-right:1em;
	/*flex-grow:1;*/
}
.menu a {
	text-decoration:none;
	color: white;
}
.menu a:hover {
	color: yellow;
}

div#menu-items {
	height:1.5em;
	padding:0.5em;
/*	margin-bottom: 2em;
*/

	vertical-align: middle;
	text-align: center;

	display:flex;
	flex-direction: row;
	justify-content: center;
}
#menu-logo {
	display:none;
}
.menu-with-logo #menu-logo {
	display:block;
}
#menu-logo img {
	padding-left:1em;
	padding-top: 0.5em;
	height:1.5em;
}

div#location {
	margin-top: 1em;
}

div.button-link {
	margin:2em;
	padding: 0.5em;

	border-radius: 8px;

	background-color: #598CE1;

	width: 260px;
	text-align: center;
	font-size:24px;
}
div.button-link.updates:hover {
	background-color: #1E531D;
}
div.button-link:hover {
	background-color: #17173C;
	box-shadow: 0px 5px 15px rgba(0,0,0,0.5);
}
.button-link a {
	color:white;
	text-decoration:none;
}
.button-link:hover a {
	color: yellow;
}

div.button-link.updates {
	background-color: #82BBFE;
}
div.button-link:hover {
}

div.panel, h1, div.timestamp, div.navigation, div#tickets, .page>p, .post>p, ul, ol, .page hr, div.button_strip {
	/*margin-top: 1em;*/
	padding: 1em;
	padding-top: 0;
	margin-left: auto;
	margin-right: auto;
	max-width:800px;
}
ol, ul {
    padding-left: 3em;
}

.page h2, .page h3, .page h4 {
	margin-left: auto;
	margin-right: auto;
	max-width:800px;
}
.page h3 {
	padding: 0.5em;
}
h2 {
    font-size: 1.2em;
}
h3 {
    font-size: 1.1em;
}
div.strip {
	width:100%;
}
div.inclusion {
	background-color: #ED622F; /* orange */
	background-color: #598DCB; /* blue */
	background-color: #8DAD5F; /* green */
	background-color: #1E531D; /* green */


	color: #FAD429; /* yellow */
	color: white;
}

.inclusion a {
	color: #FAD429; /* yellow */
	text-decoration: none;
}
.inclusion a:hover {
	color: white;
}

.panel p {
	padding-bottom: 1em;
}
h1 {
	margin-top: 1em;
	color:#598CE1;
}

h1.post-title {
	font-size:1.4em;
	line-height: 1.1em;
	margin-top: 0em;
	padding-bottom: 0.2em;
	color:#444444;
}
h1.old-news {
    margin-top: 1em;
}

div.navigation {
	display:flex;
	flex-direction: column;
	font-family: "Nanum Gothic", sans-serif;
	font-size:small;
}
div.navigation a {
	text-decoration: none;
}
div.navigation a:hover {
	text-decoration: underline;
}
h2 {
	color:#598CE1;
}

h1 a {
	text-decoration: none;
	color:black;
}
h1 a:hover {
	color:blue;
}

hr {
    display: block;
    height: 1px;
    border: 0;
    border-top: 1px solid #CCCCCC;
}

div.footer {
	width:100%;
	padding-top: 1em;
	padding-bottom: 1em;
	margin:1em;
	display:flex;
	flex-direction: row;
	justify-content: center;
	align-items: center;

	font-size:12px;
}

div.footer div {
	margin-left:1em;
	margin-right: 1em;
}
div.footer a {
	text-decoration: none;
	color: black;
}
div.footer a:hover {
	text-decoration: underline;
	color: blue;
}
div.footer img {
	width: 32px;
}

div#twitter {
}

div.timestamp, .tags {
	font-family: "Nanum Gothic", sans-serif;
	font-size:small;
	color:#888888;
	white-space: nowrap;
	padding-top: 0px;
}
div.post-meta {
	margin-bottom: 1em;
}
img.postImage {
	width:100%;
}
div.img_strip {
	display:flex;
	flex-direction: row;
	justify-content: space-between;	
}
.img_strip img {
	height: 340px;
}
div.sponsors_strip {
	display:flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	padding-top:1em;
	padding-bottom:0px;
}
.sponsors_strip img {
	height: 90px;
	margin-left:1em;
	margin-right:1em;
	margin-bottom:1em;
}

div.sponsors_column {
	flex-direction: column;
}

.sponsors-gold img {
	height: 120px;
	padding-left:1em;
	padding-right:1em;
}
.sponsors-bronze img {
	height: 80px;
}
.session-panel .sponsors-bronze {
    justify-content: flex-end;
}
.session-panel .sponsors-bronze img {
	height: 40px;
}
.sponsors_column img {
	height: 140px;
}
.community_sponsors img { /* deprecated */
	height: 60px;
}
div.sponsors-community {
}
.sponsors-community img {
	height: 60px;
}
.session-panel .sponsors-community img {
	height: 40px;
}

div.button_strip {
	display:flex;
	flex-direction: row;
	justify-content: center;
	align-items: flex-start;
	align-content: flex-start;
}
.button_strip div {
	height: 3em;
}

div.logos div {
	width:160px;
}
.logos img {
	height: 120px;
	margin-left:1em;
	margin-right:1em;
	margin-bottom:1em;
}

.reddit {
	width:74px;
	height:52px;
}
div.info {
    /*background-color: #F5F5F5;*/
    /*padding: 1em;*/
	margin-bottom: 1em;
    /*border-radius: 8px;*/
	font-size: 16px;

}
h2.session_title {
	color: #4f4f4f;
	font-size:28pt;
}

div.abstract {
}
div.session {
	margin-top: 1em;
	display:flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: flex-start;
}
div.about-speakers {
	width: 500px;
	padding:0px;
	margin:0px;
	vertical-align: top;
}
div.about-speakers-with-header {
	position: relative;
	top: -150px;
}
div.speaker-bio {
	background-color: #4f4f4f;
	color: white;
    padding: 1em;
	margin:0;
	margin-right:2em;
	margin-bottom: 1em;
    border-radius: 12px;
	font-size: 14px;
	vertical-align: top;
}
.about-speakers-with-header div.speaker-bio {
	border-width: 4px;
	border-color: white;
	border-style: solid;
}
.speaker-bio h2 {
	margin-top: 1em;
}
.about-speakers img {
	width: 300px;
	margin-top:1em;
}
.speaker-bio a {
	color:inherit;
}
.session-type {
	display:flex;
	flex-direction: row;
	flex-wrap:wrap;
	justify-content: flex-start;
	margin-bottom: 0;
	white-space: nowrap;
}
.session-type div {
	background-color: #EAEAEA;
	border-radius: 4px;
	color: #598CE1;
	font-size:12pt;
	padding: 0.3em 0.7em 0.3em 0.7em;
	margin-right:1em;
	margin-top: 0.25em;
}
.levels {
	margin-top: 0.25em;
	margin-bottom: 1em;
}
div.level-Beginner {
	color: white;
	background-color: #88CF88;
}
div.level-Intermediate {
	background-color: #82BBFE;
	color: white;
}
div.level-Advanced {
	color: white;
	background-color: #ff6666;
}
div.level-Everyone {
	color: white;
	background-color: #EFC429;
}

.abstract a {
	text-decoration: none;
}

div.video {
	justify-content: flex-end;
}
div.video div {
  	background-image: url('assets/youtube_social_icon_red.png');
	background-position:4px center;
  	background-repeat: no-repeat;
  	background-size: 30px;

	padding-left:3em;
	color: black;
}


img.rss_news {
	width:36px;
}

img.center_img {
	margin-left:auto;
	margin-right:auto;
	display: block;
}

table.sessionTable td {
	padding-left:2em;
}
table.sessionTable td.speaker {
	font-weight: bold;
}
img.social-media-icon {
	width: 32px;
	margin-right:0.5em;
}
div.header {
	width:100%;
}
div.header img {
	width:100%;
}
div.session-panel {
	padding:1em;
	padding-top:0px;
	margin-left: auto;
	margin-right: auto;
	max-width:900px;
}

.session-panel p {
	padding-bottom: 1em;
}
.abstract div.button-link {
	margin: 0px;
}

.sched-1-track {
	grid-template-columns: 60px auto;
}
.sched-3-track {
	grid-template-columns: 60px auto auto auto;
}
.sched-4-track {
	grid-template-columns: 60px auto auto auto auto;
}
.sched-day {
	display: grid;
	grid-template-rows: auto;
	grid-gap: 4px;
	font-size: 10pt;
}
.sched-day > div {
	padding:0.5em;
	border-radius: 4px;
}

.sched-3-track > div.no-tracks {
	grid-column-start: 2;
	grid-column-end: 5;
}
.sched-4-track > div.no-tracks {
	grid-column-start: 2;
	grid-column-end: 6;
}
.sched-4-track > div.one-track {
	grid-column-start: 2;
	grid-column-end: 5;
}

div.time {
}
div.no-tracks {
	grid-column-start: 2;
	grid-column-end: 5;
	background-color: #f0f0f0;
	text-align: center;
}
div.track-session {
	background-color: #598CE1;
	color: white;
	margin-top:5px;
	margin-bottom: 5px;
}
div.mini-workshop {
	margin-top:0;
	margin-bottom: 0;
}

div.sched-90 {
	background-color: #82BBFE;
	color: black;
}
p.schedule-title {
	/*font-weight: bold;*/
	font-size: 14pt;
}
p.schedule-speaker {
	font-style: italic;
	font-size: 10pt;
	padding-bottom: 0;
}
div.room-name {
	background-color: #AAAAAA;
	text-align: center;
	font-weight: bold;
}
div.room-name a {
	text-decoration: none;
	color: white;
}
div.room-name a:hover {
	text-decoration: default;
	color: blue;
}

.track-session a, .sched-keynote a, .sched-lightning a {
	text-decoration:none;
	color:inherit;
}
.sched-cell {
	padding: 0.5em;
	border-radius: 4px;
	border-bottom: solid 1px rgba(80,80,80,0);
	border-right: solid 1px rgba(80,80,80,0);
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}
.session-panel > p {
	margin: 0px;
	padding: 0px;
	margin-top: 2em;
	text-align: right;
	width:100%;
	font-size:32pt;
	font-weight: bold;
	color: 17173C;
}
div.sched-intro {
	background-color: #FFC94E;
	font-size: 14pt;
}
div.sched-lunch {
	background-color: inherit;
}
div.sched-lightning {
	background-color: #FFE957;
	font-size: 14pt;
}
div.sched-dinner {
	background-color: #9DBD6F;
	font-size: 14pt;
	color: white;
}
div.sched-keynote {
	background-color: #FF9D43;
	color: black;
}
.track-session .sched-cell:hover {
	background-color: rgba(128,128,128,0.1);
	border-bottom: solid 1px rgba(80,80,80,0.1);
	border-right: solid 1px rgba(80,80,80,0.1);
}
div.page-header {
	padding-top: 1em;
	margin-bottom: 1em;
  	background-image: url('assets/half-banner.jpeg');
	width:100%;
	overflow: hidden;
	object-fit: cover;
	background-position: center center;
  	background-repeat: no-repeat;
  	background-size: cover;
}
div.page-header h1 {
	font-family: 'Montserrat', "Avenir Next", sans-serif;
	font-size: 44px;
	color: white;
	padding:0;
	padding-top:0.5em;
	padding-bottom: 1em;
	margin-top:0;
}
/*div.odd-track {*/
	/*position:relative;*/
	/*top:-3px;*/
/*}*/
/*div.even-track {*/
	/*position:relative;*/
	/*top:3px;*/
/*}*/
div.small-speakers {
	margin-left: auto;
	margin-right: auto;
	margin-top: 1em;
	margin-bottom: 1em;
	padding: 0;
	display:flex;
	flex-direction: row;
	flex-wrap: wrap;
	max-width:800px;

}
.small-speakers img {
	height:100px;
	margin: 0px;
	padding: 0px;
}
.small-speakers-2 img {
	height:114px;
}

div._404 {
	width:100%;
	height:500px;
	object-fit: cover;
	background-position: center center;
  	background-repeat: no-repeat;
  	background-size: cover;
  	background-image: url('assets/rays-over-sea.jpg');

	font-size: 14pt;

	display: flex;
	flex-direction: column;
  	align-items: center;
  	justify-content: center;
	margin-top:0;
	padding-top:0;
	color: white;
}
._404 div:first-child {
	font-size: 44pt;
	font-weight: bold;
	color:black;
}

div.sticky_schedule_header {
	position:sticky;
	position: -webkit-sticky;
	top:50px;
}
.sticky_schedule_header div.sponsors_strip {
	background-color: white;
    border-bottom: 1px solid #e0e0e0;
    padding-bottom: 0;
    margin-bottom: 0;
}
.sticky_schedule_header .sponsors-gold img {
	height:80px;
}

div#day-menu {
	display: flex;
	flex-direction: row;
    justify-content: center;
    background-color: rgba(256, 256, 256, 0.5);
}

div#day-menu > div {
   	background-color: #82BBFE;
	border-radius: 0 0 4px 4px;
	font-size:12pt;
	font-weight: bold;
	padding: 0.3em 0.6em 0.3em 0.6em;
	margin-right:4px;
	margin-top: 0;
    margin-bottom: 1em;
}
div#day-menu a {
    text-decoration: none;
    color: black;
}
div#day-menu a:hover {
    color: blue;
}
div.old-news a {
    text-decoration: none;
    color: black;
}
div.old-news a:hover {
	text-decoration: underline;
	color: blue;
}

/* specific to the hotels page */
.clifton img {
	height: 230px;
}
.view img {
	height: 280px;
}
