/* colors */
.dark-blue { color: #343F63; }
.dark-green { color: #297373; }



/* generic styles */
body { font-size: 0.875rem; }

h1, h2, h3, h4, h5, h6 { color: #343F63; }
img { max-width: 100% ; }


.row.card-header {
	margin-left: 0;
	margin-right: 0;
}


.hide,
.e2hid { display: none; }

.btn-warning { background-color: #ffe302;}
.btn-warning:hover { background-color: #f2dd6e; }

/* Page Styles */
main {
	
}
/* Header */
.masthead.bg-dark {
	background-color: #343F63 !important;
}
.masthead .show>.btn-outline-menu {
	background-color: #343F63;
	box-shadow: none;
}
.masthead .navbar-brand {
	margin-top: -8px;
    margin-bottom: -60px;
    padding: 10px;
	background-color: #fff;
	-webkit-box-shadow: -1px 1px 3px 0px rgba(61,61,61,0.64);
	-moz-box-shadow: -1px 1px 3px 0px rgba(61,61,61,0.64);
	box-shadow: -1px 1px 3px 0px rgba(61,61,61,0.64);
}
.masthead .navbar-brand img {
	width: 125px;
}
.navbar-brand {
	z-index: 8000;
}
@media (max-width: 767.99px) { 
	.navbar-nav {
		margin-top: 60px;
	}
}


/* Footer */
.site-footer {
	font-size: 0.8rem;
	background-color: #343F63;
}
.site-footer a,
.site-footer a:visited {
	color: #fff;
	opacity: 0.7;
}
.site-footer a:hover,
.site-footer a:active {
	opacity: 0.9;
}
.site-footer h5 {
	font-size: 1rem;
}
.site-footer small {
	display: block;
	font-size: 0.6rem;
	text-align: center;
}
.footer-logo {
	text-align: center;
}

.current-student em {
  color: #297373;
}


/************************************************
	 Specific Module Styles 
 ************************************************/

/* Class Schedule */
.important-dates .event-list > li > time > .day {
	font-size: 36px;
}
.important-dates .event-list > li time > .month {
	font-size: 18px;
}
.important-dates .event-list > li > .info > .title {
	font-size: 15px;
}
.important-dates .event-list > li > .info > .desc {
	font-size: 14px;
}
.event-list.classes-begin li time {
	background-color: #297373;
}
.event-list.reg-begins li time {
	background-color: #f2dd6e;
	color: #333;
}
.event-list.reg-begins.disabled {
	opacity: 50%; 
}
@media (min-width: 768px) {
	.important-dates .event-list > li {
		height: 100px;
	}
	.important-dates .event-list > li > time {
		height: 100px;
		width: 60px;
	}
	.important-dates .event-list > li > .info {
		height: 100px;
	}
}


.class-schedule table { width: 100%; }
.class-schedule tbody { border-top: 4px solid #333; }
.class-schedule th,
.class-schedule .row-heading span {
	text-align: center;
	background-color: rgb(245, 245, 245); 
	border: 1px solid #999; 
	border-collapse: collapse;
}
.class-schedule .row-heading .heading {
	display: block;
    margin: -0.5rem -0.5rem 0.5rem;
    font-weight: bold;
    border: 0;
    border-bottom: 1px solid #999;
}
.class-schedule .full {
  margin: 0 -0.5rem;
  padding: 0.5rem;
}
.class-schedule .row-heading > div {
	margin: -0.5rem;
    padding: 0.5rem;
}
.class-schedule td { 
	padding: 0.5rem;
	border: 1px solid #999; 
	border-collapse: collapse; 
}
.class-schedule table .day {
	display: block;
	transform: rotate(-90deg);
	margin: 0 -1.2em;
	font-size: 1.3em;
}
.class-schedule .no-class {
	background-color: #f2f2f2;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='4' height='4' viewBox='0 0 4 4'%3E%3Cpath fill='%23d0d0d0' fill-opacity='0.4' d='M1 3h1v1H1V3zm2-2h1v1H3V1z'%3E%3C/path%3E%3C/svg%3E");
}

.class-schedule h5 {
	margin-bottom: 0;
	font-size: 1.1rem;
}
.class-schedule a {
	color: #369;
}
.class-schedule p {
	margin-bottom: 0.7em;
}
.class-schedule .full {
	background-color: rgba(219, 233, 238, 1); 
}
.class-schedule .eyebrow {
  color: #999;
}
/* Added for templates 100 and above */

.class-schedule .schedule-desktop td {
  padding: 0 0.5rem 0.5rem;
  vertical-align: top;
}

.schedule-desktop .heading {
  margin: 0 -0.5rem;
  padding: 0.1rem 0.2rem;
  text-align: center;
  font-weight: 600;
  background-color: #eedd7e;
}

.class-schedule .schedule-desktop th {
  background-color: #eedd7e;
}


.class-schedule .admin-funcs,
.class-schedule .admin-funcs a { color: #c52c65; }
.class-schedule .admin-funcs a:hover { color: #cc2936; }


	//#class-schedule td:hover .admin-funcs { display: block; }
	//#class-schedule .admin-funcs { display: none; position: absolute; top: 0; right: 0; padding: 2px; background: rgba(0, 0, 0, 0.7); }
	//#class-schedule .admin-funcs a { display: block; height: 20px; width: 20px; background: url('../images/sprite_class_full.png') 0 -40px no-repeat; }
	//#class-schedule .admin-funcs .unfill-class { background-position: 0 0; }
	//#class-schedule .admin-funcs .unfill-class:hover { background-position: 0 -60px; }
	//#class-schedule .admin-funcs .fill-class:hover { background-position: 0 -20px;  }

	//.admin-seats { font-size: 12px; margin-top: 0.5em; color: #990000; }

.mobile-schedule .day,
.mobile-schedule .time {
	padding: 0.5rem;
	text-align: center;
}
.mobile-schedule .day {
	font-weight: 700;
	color: #fff;
	background-color: #40798c;
}
.mobile-schedule .time {
	background-color: rgb(245, 245, 245); 
}
.mobile-schedule .col-6,
.mobile-schedule .col-12 {
	padding: 0.7rem;
	border: 1px solid #ccc;
	border-left: 0;
}
.mobile-schedule .col-6:first-child,
.mobile-schedule .col-12:first-child {
	border-left: 1px solid #ccc;
}
#rabies-error { font-size: 0.8em; }

/* Contact Us */
#map-jumbotron {
	padding: 0;
}
#map-container {
	height: 300px;
	width: 100%;
}

.footnotes {
  margin: 1rem 0;
}
.footnotes ol {
  list-style: none;
}

/* Instructors */
.instructor-bio .jumbotron {
	height: 12rem;
	background-color: #f2dd6e;
background-image: url("data:image/svg+xml,%3Csvg width='200' height='200' viewBox='0 0 100 100' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M11 18c3.866 0 7-3.134 7-7s-3.134-7-7-7-7 3.134-7 7 3.134 7 7 7zm48 25c3.866 0 7-3.134 7-7s-3.134-7-7-7-7 3.134-7 7 3.134 7 7 7zm-43-7c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zm63 31c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zM34 90c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zm56-76c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zM12 86c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm28-65c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm23-11c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zm-6 60c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm29 22c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zM32 63c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zm57-13c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zm-9-21c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zM60 91c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zM35 41c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zM12 60c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2z' fill='%23fff3b3' fill-opacity='0.4' fill-rule='evenodd'/%3E%3C/svg%3E");
	background-repeat: repeat;
	background-size: initial;
} 
.instructor-bio > .row {
	margin-top: -10rem;	
}
.instructor-bio img {
	margin-bottom: 1rem;
	border: 1rem solid #fff;
	-webkit-box-shadow: 3px 3px 2px 1px rgba(0,0,0,0.46);
	-moz-box-shadow: 3px 3px 2px 1px rgba(0,0,0,0.46);
	box-shadow: 3px 3px 2px 1px rgba(0,0,0,0.46);
}
.instructors .card-title a {
	color: #343F63;
}

.instructors .card {
	text-align: center;
	margin-bottom: 2em;
}
.instructors small {
	font-style: italic;
}
.instructors .bio {
	font-size: 0.8rem;
	text-align: left;
}

.instructors.card-deck > .card {
    flex-wrap: wrap;
	flex: initial; 
}

/* Small devices (landscape phones, 576px and up) */
@media (min-width: 768px) { 
	.instructors .card {
		width: 22%;
	}
}
@media (min-width: 576px) and (max-width: 767.99px) { 
	.instructors .card {
		width: 44%;
	}
}
/* Extra small devices (portrait phones, less than 576px) */
@media (max-width: 575.99px) {  
	.instructors .card {
		width: 100%;
	}
}
 
 
/* Event List */
  
.event-list {
	list-style: none;
	margin: 0px;
	padding: 0px;
}
.event-list .eyebrow {
	text-transform: uppercase;
	opacity: 0.8;
}
.event-list > li {
	background-color: rgb(255, 255, 255);
	padding: 0px;
	margin: 0px 0px 20px;
}
.event-list > li > time {
	display: inline-block;
	width: 100%;
	color: rgb(255, 255, 255);
	background-color: rgb(197, 44, 102);
	padding: 5px;
	text-align: center;
	text-transform: uppercase;
}
.event-list > li:nth-child(even) > time {
	background-color: rgb(64, 121, 140);
}
.event-list > li > time > span {
	display: none;
}
.event-list > li > time > .day {
	display: block;
	font-size: 56pt;
	font-weight: 100;
	line-height: 1;
}
.event-list > li time > .month {
	display: block;
	font-size: 24pt;
	font-weight: 600;
	line-height: 1;
}
.event-list > li > .info {
	padding-top: 5px;
	text-align: center;
}
.event-list > li > .info > .title {
	font-size: 17pt;
	font-weight: 700;
	margin: 0px;
}
.event-list > li > .info > .desc {
	font-size: 13pt;
	font-weight: 300;
	margin: 0px;
}
.event-list > li > .info > ul {
	display: table;
	list-style: none;
	margin: 10px 0px 0px;
	padding: 0px;
	width: 100%;
	text-align: center;
}
.event-list > li > .info > ul > li {
	display: table-cell;
	cursor: pointer;
	color: rgb(30, 30, 30);
	font-size: 11pt;
	font-weight: 300;
    padding: 3px 0px;
}
.event-list > li > .info > ul > li > a {
	display: block;
	width: 100%;
	color: rgb(30, 30, 30);
	text-decoration: none;
} 
.event-list > li > .info > ul > li:hover {
	color: rgb(30, 30, 30);
	background-color: rgb(200, 200, 200);
}
@media (min-width: 768px) {
	.event-list > li {
		position: relative;
		display: block;
		width: 100%;
		height: 120px;
		padding: 0px;
	}
	.event-list > li > time {
		display: inline-block;
	}
	.event-list > li > time {
		width: 120px;
		float: left;
	}
	.event-list > li > .info {
		background-color: rgb(245, 245, 245);
		overflow: hidden;
	}
	.event-list > li > time {
		width: 120px;
		height: 120px;
		padding: 0px;
		margin: 0px;
	}
	.event-list > li > .info {
		position: relative;
		height: 120px;
		text-align: left;
		padding-right: 40px;
	}	
	.event-list > li > .info > .title, 
	.event-list > li > .info > .desc,
	.event-list > li > .info > .eyebrow {
		padding: 0px 10px;
	}
	.event-list > li > .info > ul {
		position: absolute;
		left: 0px;
		bottom: 0px;
	}
} 


.get-updates {
	text-align: center;
	background-color: #c0d6df;
}
.get-updates .btn {
	display: block;
	width: 100%;
}

.how-do-i {
	text-align: center;
	background-color: #f2dd6e;
}


/* Jumbotrons */


.jumbotron {
	background-size: cover;
	background-color: #fff;
}
.jumbotron.about {
	height: 40vw;
	background-image: url('../images/cover/about-us-cover.jpg');
	background-repeat: no-repeat;
	background-position: center;
}
#main-jumbotron {
	background-image: url('../images/cover/bates-header.jpg');
	background-position: center;
}
.jumbotron .intro-text {
	background-color: rgba(255,255,2555,0.6);
}
/* Small devices (landscape phones, less than 768px) */
@media (max-width: 767.99px) { 
	.jumbotron {
		background-size: 100%;
		background-repeat: no-repeat;
		background-position: center top;
	}
	#main-jumbotron {
		background-position: center top;
	}
	.jumbotron .intro-text {
		margin-top: 32vw;
	}

}


/* my profile */
.my-profile-dogs h5 {
	margin: 0;
}
.my-profile-dogs .card-body p {
	width: 50%;
	float: left;
}
.profile-dogs .card-body .experience {
	clear: left;
}
.profile-dogs .card .card-header,
.my-registrations .card .card-header {
	background-color: rgba(112,169,161, 0.4);
}
.profile-dogs .card .card-header a,
.my-registrations .card .card-header a, 
.my-registrations .card .profile-controls a {
	color: #40798c;
}
.profile-dogs .card.inactive .card-header {
	background-color: rgba(0,0,0,.03);
}
.profile-dogs .card.inactive {
	color: #999;
}
.profile-dogs .card.inactive .card-header a {
	color: #999;
}
.profile-controls .fa {
	padding-left: 1ex;
	font-size: 1.2rem;
}
.profile-dogs .card .card-header .profile-controls a:hover,
.profile-dogs .card.inactive .card-header .profile-controls a:hover,
.my-registrations .card .profile-controls a:hover {
	color: #c52c65;
}
.frm-edit-dog legend {
	font-size: 1rem;
}
.frm-edit-dog .venue-registrations {
	padding: 0;
}
.my-registrations .card-body {
	padding: 0;
}
.my-registrations .card-body > .row {
	padding: 0.5rem 1rem;
	margin-right: 0;
	margin-left: 0;
}
.my-registrations .card-body > .row:nth-child(even) {
	background-color: #eee;
}

/* newsletter */
#news-subscribed,
#news-error {
	display: none;
}

/* pick your path */
.pick-your-path {
	text-align: center;
	background-image: url('../images/path.svg'), url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI1MCIgaGVpZ2h0PSI1MCI+CjxyZWN0IHdpZHRoPSI1MCIgaGVpZ2h0PSI1MCIgZmlsbD0iI2ZmZiI+PC9yZWN0Pgo8cmVjdCB3aWR0aD0iMSIgaGVpZ2h0PSI0OCIgZmlsbD0iI2Y5ZjlmOSIgeT0iMSI+PC9yZWN0Pgo8cmVjdCB3aWR0aD0iNDgiIGhlaWdodD0iMSIgZmlsbD0iI2Y5ZjlmOSIgeD0iMSI+PC9yZWN0Pgo8L3N2Zz4=")
	;

	background-repeat: no-repeat, repeat;
	background-position: 50% 3rem, 0 0;
}
.pick-your-path h3 {
	margin-top: 1.125rem;
}
.pick-your-path .col-lg-4 {
	
}
.pick-your-path img.rounded-circle {
	max-width: 180px;
}
.pick-your-path .btn-active {
	background-color: #343F63 !important;
}
/* Small devices (landscape phones, less than 768px) */
@media (max-width: 767.99px) { 
	.pick-your-path .col-md-4 {
		margin-top: 1.5rem;
	}
	.pick-your-path h3 {
		margin-top: 0;
	}
	.pick-your-path img.rounded-circle {
		float: left;
		max-width: 30%;
	}
	.pyp-text {
		overflow: hidden;
		padding-left: 1ex;
		text-align: left;
	}
}


.registration-how-to .list-unstyled span {
	height: 3rem;
	width: 3rem;
	font-size: 2.3rem;
	line-height: 3rem;
	text-align: center;
	color: #fff;
	background-color: #343F63;
	border-radius: 50%;
}



/* Seminar */
.seminars {
	font-size: 1.2em;
}

.seminar-days li {
	padding-left: 2rem;
}
.seminar-days h5 {
	font-size: 2rem;
}
.seminar-days .date-time {
	margin-bottom: 0;
	padding-left: 3px;
	font-size: 1.2rem;
	background-color: #eee;
}


.seminar-announce {
	background-color: #297373;
	color: #fff;
}
.seminar-announce h4 { color: #fff; }
.seminar-announce a { color: rgba(255,255,255, 0.7); }
.seminar-announce a:hover { color: rgba(255,255,255, 1); }

.seminar-date-reg .form-check-inline { margin: 0.5rem; }
.seminar-date-reg .form-check-input { margin-left: 0; }
.seminar-date-reg .form-check-inline .form-check-label { vertical-align: top; }


/* Student Spotlight */
.student-spotlight figcaption small {
	display: block;
	text-align: right;
	opacity: 0.8;
}
.student-spotlight figcaption h5 {
	text-align: center;
}
.student-spotlight img {
	max-width: 240px;
}

/* -----------------------------------------------
 * Timeline
 * --------------------------------------------- */
 .timeline {
    list-style: none;
    padding: 10px 0;
    position: relative;
    font-weight: 300;
    height: 90%;
}
.timeline:before {
    top: 0;
    bottom: 0;
    position: absolute;
    content:" ";
    width: 2px;
    background: #343F63;;
    left: 50%;
    margin-left: -1.5px;
}
.timeline > li {
    margin-bottom: 20px;
    position: relative;
    width: 50%;
    float: left;
    clear: left;
}
.timeline > li:before, .timeline > li:after {
    content:" ";
    display: table;
}
.timeline > li:after {
    clear: both;
}
.timeline > li:before, .timeline > li:after {
    content:" ";
    display: table;
}
.timeline > li:after {
    clear: both;
}
.timeline > li > .timeline-panel {
    width: calc(100% - 25px);
    width: -moz-calc(100% - 25px);
    width: -webkit-calc(100% - 25px);
    float: left;
    border: 1px solid #999;
    background: #ffffff;
    position: relative;
}
.timeline > li > .timeline-panel:before {
    position: absolute;
    top: 26px;
    right: -15px;
    display: inline-block;
    border-top: 15px solid transparent;
    border-left: 15px solid #999;
    border-right: 0 solid #999;
    border-bottom: 15px solid transparent;
    content:" ";
}
.timeline > li > .timeline-panel:after {
    position: absolute;
    top: 27px;
    right: -14px;
    display: inline-block;
    border-top: 14px solid transparent;
    border-left: 14px solid #ffffff;
    border-right: 0 solid #ffffff;
    border-bottom: 14px solid transparent;
    content:" ";
}
.timeline > li > .timeline-badge {
    color: red;
    width: 24px;
    height: 24px;
    line-height: 50px;
    text-align: center;
    position: absolute;
    top: 16px;
    right: -12px;
    z-index: 100;
}
.timeline > li.timeline-inverted > .timeline-panel {
    float: right;
}
.timeline > li.timeline-inverted > .timeline-panel:before {
    border-left-width: 0;
    border-right-width: 15px;
    left: -15px;
    right: auto;
}
.timeline > li.timeline-inverted > .timeline-panel:after {
    border-left-width: 0;
    border-right-width: 14px;
    left: -14px;
    right: auto;
}
.timeline-badge > a {
    color: red !important;
}
.timeline-badge.path-1 > a {
    color: rgba(41,115,115, 1) !important;
}
.timeline-badge.path-2 > a {
    color: rgba(64,121,140, 1) !important;
}
.timeline-badge.path-3 > a {
    color: rgba(197,44,101, 1) !important;
}
.timeline-badge a:hover {
    color: #999 !important;
}
.timeline-title {
    margin-top: 0;
    color: inherit;
}
.timeline-heading h4 {
    font-weight: 400;
    padding: 0 15px;
    color: #4679bd;
}
.timeline-body > p, .timeline-body > ul {
    padding: 10px 15px;
    margin-bottom: 0;
}
.timeline-footer {
    padding: 5px 15px;
    background-color:#f4f4f4;
}
.timeline-footer.path-1 {
	background-color: rgba(41,115,115, 0.3);
}
.timeline-footer.path-2 {
	background-color: rgba(64,121,140, 0.3);
}
.timeline-footer.path-3 {
	background-color: rgba(197,44,101, 0.3);
}
.timeline-footer p { margin-bottom: 0; }
.timeline-footer > a {
    cursor: pointer;
    text-decoration: none;
}
.timeline > li.timeline-inverted {
    float: right;
    clear: right;
}
.timeline > li:nth-child(2) {
    margin-top: 60px;
}
.timeline > li.timeline-inverted > .timeline-badge {
    left: -12px;
}
.no-float {
    float: none !important;
}
.timeline .promo-image {
	background-color: #eee;
}
.timeline .video-embed {
    overflow:hidden;
    padding-bottom:56.25%;
    position:relative;
    height:0;
}
.timeline .video-embed iframe{
    left:0;
    top:0;
    height:100%;
    width:100%;
    position:absolute;
}
.pick-your-path .tab-content>.tab-pane.show {
	display: block;
}

@media (max-width: 767px) {
    ul.timeline:before {
        left: 40px;
    }
    ul.timeline > li {
        margin-bottom: 0px;
        position: relative;
        width:100%;
        float: left;
        clear: left;
    }
    ul.timeline > li > .timeline-panel {
        width: calc(100% - 65px);
        width: -moz-calc(100% - 65px);
        width: -webkit-calc(100% - 65px);
    }
    ul.timeline > li > .timeline-badge {
        left: 28px;
        margin-left: 0;
        top: 16px;
    }
    ul.timeline > li > .timeline-panel {
        float: right;
    }
    ul.timeline > li > .timeline-panel:before {
        border-left-width: 0;
        border-right-width: 15px;
        left: -15px;
        right: auto;
    }
    ul.timeline > li > .timeline-panel:after {
        border-left-width: 0;
        border-right-width: 14px;
        left: -14px;
        right: auto;
    }
    .timeline > li.timeline-inverted {
        float: left;
        clear: left;
        margin-top: 30px;
        margin-bottom: 30px;
    }
    .timeline > li.timeline-inverted > .timeline-badge {
        left: 28px;
    }
}

.embed-container { 
	position: relative; padding-bottom: 56.25%; height: 0; overflow: hidden; max-width: 100%; 
	margin-bottom: 1em; } 
.embed-container iframe, 
.embed-container object, 
.embed-container embed { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }