@charset "UTF-8";
/* CSS Document */

@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@100;400;700&display=swap');

html, body {
	height: 100%;
	width: 100%;
	margin: 0;
}

label, h4, table, ul {
	font-family: 'Outfit', Arial, Helvetica, sans-serif;
	color: #6D6E71 !important;
}
table {
	font-family: 'Outfit', Arial, Helvetica, sans-serif;
	color: #6D6E71 !important;
	font-size: 15px;
}


.logosvg {
    position: absolute;
    bottom: 0;
    left: 50%;
    width: 100%;
    padding-bottom: 100px;
    -webkit-transform: translate(-50%);
    -ms-transform: translate(-50%);
    -moz-transform: translate(-50%);
    -o-transform: translate(-50%);
    transform: translate(-50%);
}

/* -- LOADING --*/

.loading {
	position: fixed;
	height: 100vh;
	width: 100%;
	top: 0;
	left: 0;
	background-color: white;
	z-index: 1000;
	text-align: center;
	vertical-align: middle;
	padding: 40px;
}

/* -- header -- */

.header {
	position: fixed;
	width: 100%;
	height: 120px;
	top: 0;
	border-bottom: solid 4px #00448D;
	background-color: white;
	z-index:10;
	box-sizing: content-box;
}
.inner-top {
	position: relative;
	top: 25%;
	height: 66.66%;
}
.layer-two {
	height: 50%;
	transition: 1s;
}
.layer-two.sub-nav {
	opacity: 0;
	height: 0;
}
.header-left {
	position: fixed;
	left: 0;
	top: 120px;
	width: 300px;
	height: calc(100% - 120px);
	border-right: solid 4px #00448D;
	box-sizing: content-box;
	transform: translate3d(0, 0, 0);
	background-color: rgba(0, 68, 141, 0.7);
	/*overflow-y: scroll;*/
}
.header-fill {
	width: calc(100% + 4px);
	height: 100%;
	margin-top: -1px;
	background-color: #00448D;
	opacity: .7;
}
.logo-cont {
	display: block;
	z-index: 100;
	overflow: hidden;
}
.logo-cont>img {
	max-width: 300px;
	padding: 20px;
}



/* -- NAVIGATION --*/


.navbar-expand-lg .navbar-nav .dropdown-menu {
    position: relative;
}
	/*-- NAV BAR --*/
.header-left>.navbar-container {
	margin-top: 20px;
	width: calc(100% - 4px);
	float: right;
	
}
.header-left .navbar-brand {
	padding: 0;
	margin: 0;
}
.header-left .bg-opblue {
	
}
.header-left .navbar {
	padding-top: 13px;
	padding-bottom: 3px;
}
.header-left .navbar button:focus {
	outline: none;
}
.header-left .dropdown-menu {
	margin: 3px 0 0;
	border-radius: 0;
	border: none;
	border-top: solid 1px #ffffff;
	border-bottom:: solid 1px #ffffff;
	min-width: 100%;
	background-color: transparent;
	color: #ffffff;
	/*-webkit-box-shadow: -1px 25px 34px 8px rgba(0,0,0,0.37);
	-moz-box-shadow: -1px 25px 34px 8px rgba(0,0,0,0.37);
	box-shadow: -1px 25px 34px 8px rgba(0,0,0,0.37);*/
}
.nav-fill .nav-item {
	text-align: left;
}
.dropdown-item {
	color: #ffffff;
	white-space: break-spaces;
	font-weight: 300;
}
.header-left .nav-item {
	font-size: larger;
}
.header-left .dropdown-item {
	font-size: large;
	display:block;

}
.header-left .dropdown-item:active {
	color: rgb(89, 169, 255);
}
.header-left .sub.dropdown-item {
	padding-left: 40px;
}
.header-left .dropdown-item:active {
	background-color: transparent;
}
.layer-three {
	white-space: nowrap;
}
.nav-headings {
	position: relative;
	height: 38%;
	top: 100%;
	transform: translate(0, -100%);
}

.navbar-light .navbar-nav .nav-link {
	color: #ffffff;
	font-weight: 300;
}	
.navbar-light .navbar-nav .nav-link:focus, .navbar-light .navbar-nav .nav-link:hover ,.navbar-light .navbar-nav .active > .nav-link, .navbar-light .navbar-nav .nav-link.active, .navbar-light .navbar-nav .nav-link.show, .navbar-light .navbar-nav .show > .nav-link {
	color: rgb(89, 169, 255);
}
.nav-heading {
	width: 16.666%;
	height: 100%;
	float: left;
	background-color: white;
}
.nav-heading:hover>.nav-sub-headings>.apc-bttn, .nav-heading:hover>.nav-sub-headings>.nav-padding {
	display: block;
}
.nav-heading:hover>.nav-sub-headings {
	border-top: solid 4px #00448D;
	transition: none;
}
.nav-sub-headings {
	display: block;
	width: 90%;
	left: 5%;
	position: relative;
	transition: 1s;
	background-color: #5b5c5e;
}
.navbar-nav {
	display: block;
}
.nav-padding {
	display: none;
	width: 100%;
	height: 3vh;
}

/* allows scrolling of nav-bar for mobile */
/* calculated on the basis of 20vh to spare and 120 for header */
.navbar-collapse.show {
	overflow-y: auto;
	margin-bottom: 30px;
	max-height: calc(95vh - 120px);
}
	
/* -- nav hamburger --*/

.navbar-light .navbar-toggler {
	display: none;
	border: none;
	padding: .25rem;
}

.nav-btn-wrap {
	position: relative;
	height: 40px;
	width: 40px;
}
.navbtn {
	-webkit-transition: transform 450ms cubic-bezier(0.4, 0, 0.2, 1) 0ms;
	-moz-transition: transform 450ms cubic-bezier(0.4, 0, 0.2, 1) 0ms;
	-o-transition: transform 450ms cubic-bezier(0.4, 0, 0.2, 1) 0ms;
	transition: transform 450ms cubic-bezier(0.4, 0, 0.2, 1) 0ms;
}
.navbtn:hover {
	cursor: pointer;
}
.st00,.st01,.st02 {
	-webkit-transition: transform 450ms cubic-bezier(0.4, 0, 0.2, 1) 0ms;
	-moz-transition: transform 450ms cubic-bezier(0.4, 0, 0.2, 1) 0ms;
	-o-transition: transform 450ms cubic-bezier(0.4, 0, 0.2, 1) 0ms;
	transition: transform 450ms cubic-bezier(0.4, 0, 0.2, 1) 0ms;
}
.navbtn.clicked {
	-webkit-transform:rotate(180deg);
	-ms-transform:rotate(180deg);
	-moz-transform:rotate(180deg);
	-o-transform:rotate(180deg);
	transform:rotate(180deg);
}
.st00.clicked {
	-webkit-transform: rotate(45deg) translate(0px,5px);
	-ms-transform: rotate(45deg) translate(0px,5px);
	-moz-transform: rotate(45deg) translate(0px,5px);
	-o-transform: rotate(45deg) translate(0px,5px);
	transform: rotate(45deg) translate(0px,5px);
}
.st01.clicked {
	-webkit-transform: rotate(135deg);
	-ms-transform: rotate(135deg);
	-moz-transform: rotate(135deg);
	-o-transform: rotate(135deg);
	transform: rotate(135deg);
	opacity:0;
	-webkit-transition: all .45s cubic-bezier(0.4,0.0,0.2,1), opacity .45s .45s;
	-moz-transition: all .45s cubic-bezier(0.4,0.0,0.2,1), opacity .45s .45s;
	-o-transition: all .45s cubic-bezier(0.4,0.0,0.2,1), opacity .45s .45s;
	transition: all .45s cubic-bezier(0.4,0.0,0.2,1), opacity .45s .45s;
}
.st02.clicked {
	-webkit-transform: rotate(135deg) translate(0px,-5px);
	-ms-transform: rotate(135deg) translate(0px,-5px);
	-moz-transform: rotate(135deg) translate(0px,-5px);
	-o-transform: rotate(135deg) translate(0px,-5px);
	transform: rotate(135deg) translate(0px,-5px);
}


/* -- CONTENT AREA BACKGROUND --*/



#player {
	position: absolute;
	top: 50%;
	left: 50%;
}
#default-background {
	position: fixed;
	min-height: 100%;
	min-width: 100%;
	background: no-repeat center center fixed;
	background-image: url(../img/stock-6.jpg);
	background-size: cover;
}

/* -- CONTENT AREA -- */
.col-2 {
	width: 50%;
	max-width: none;
}
a.anchor {
	display: block;
	position:relative;
	visibility: hidden;
	top: -160px;
}
.content-body {
	position: absolute;
	top: calc(120px + 4px);
	width: 100%;
}
.inner-content-body {
	background-color: white;
	padding-bottom: 25px;
}
.text-content {
	padding: 4em 16.666% 0;
	position: relative;
	margin-top: 66vh;
}
.heading-border>h1 {
	font-size: 60px;
	font-family: 'Outfit', Arial, Helvetica, sans-serif;
	font-weight: 700;
	margin: 0 10px;
	color: #111111;
}
.sub {
	font-size: 36px;
	font-family: 'Outfit', Arial, Helvetica, sans-serif;
	font-weight: 400;
	margin: 0 10px;
	font-style: italic;
	color: #999999;
}
.heading-border>h2 {
	font-size: 35px;
	font-family: 'Outfit', Arial, Helvetica, sans-serif;
	font-weight: 700;
	color: #111111;
	padding-top: 50px;
}
.heading-border>h3 {
	font-size: 35px;
	font-family: 'Outfit', Arial, Helvetica, sans-serif;
	font-weight: 100;
	color: rgb(247, 217, 67);
}
.heading-border.inc-sub {
	display: inline-block;
	width:100%;
}
.heading-border.inc-sub>h1, .heading-border.inc-sub>h2 {
	width:65%;
	display:inline-block;
}
.page-subheading {
	width: 30%;
	display: inline-block;
	margin: 0;
}
.page-subheading>span {
	position: absolute;
	bottom:10px;
}
.heading-border {
	border-bottom: solid 2px #a90533;
}
.heading-border.sub-border {
	width: 95%;
	margin-bottom: 40px;
	border-bottom: solid 2px #a90533;
}
.intro {
	padding-top: 3em;
	padding-left: 10px;
	padding-right: 10px;
	font-size: 16px;
	font-family: 'Outfit', Arial, Helvetica, sans-serif;
	font-weight: 400;
	color: #6D6E71;	
	margin: 0;
}
ul.intro {
	padding-top: 1em;
}
ul>li {
	font-family: 'Outfit', Arial, Helvetica, sans-serif;
}
ul>li>span {
	margin-left: 5px;
}
ol p {
	padding: 0;
}
p, ol li {
	font-size: 16px;
	font-family: 'Outfit', Arial, Helvetica, sans-serif;
	font-weight: 400;
	color: #6D6E71;	
	padding: 10px 16px 10px 10px;
	margin: 0;
}

.notoppad {
	padding-top: 0;
}

.nobotpad {
	padding-bottom: 0;
}

.nopad {
	padding: 0;
}

.light {
	/*font-weight: 300;*/
	font-style: italic;
}

.fs48 {
	font-size: 48px !important;
}

h2 {
	font-size: 30px;
	font-family: 'Outfit', Arial, Helvetica, sans-serif;
	font-weight: 700;
	margin: 30px 10px 10px 10px;
	color: #111111;
}

h3 {
	font-size: 20px;
	font-family: 'Outfit', Arial, Helvetica, sans-serif;
	font-weight: 400;
	margin: 20px 10px 10px 10px;
	color: #111111;
}

a.cta-button {
	margin: 15px 10px;
	padding: 12px 15px;
	color: #fff;
	font-weight: bold;
	background-color: #00448D;
	display: inline-block;
	border-radius: 3px;
}

a.cta-button:hover {
	background-color: #a90533;
}

.roxy-blue-text {
	color: #00448D !important;
}

.sentence-heading {
	padding-top: 3em;
}
.small-break {
	position: relative;
	margin: 2em 0 1em;
	height: 3px;
	width: 20%;
	opacity: .3;
	left: 50%;
	border: none;
	background-color: #96D6D3;
	-webkit-transform: translate(-50%);
	-ms-transform: translate(-50%);
	-moz-transform: translate(-50%);
	-o-transform: translate(-50%);
	transform: translate(-50%);
}
.break-quote {
	font-family: 'PT Sans', sans-serif;
	font-style: italic;
	font-size: 25px;
	text-align: center;
	color: #96D6D3;
    padding: 0 0 1em 0;
}
.sub-text {
	padding: 3em 0;
	width: 100%;
}
.intext-author-img {
	position: relative;
	float: right;
	margin-left: 25px;
	width: 40%;
	padding-bottom: 20px;
}
.intext-img {
	position: relative;
	float: right;
	margin-top: 4.26em;
	margin-left: 25px;
	height: 30em;
	width: 50%;
}
.intext-img-full {
	position: relative;
	width: 100%;
	height: 30em;
	margin: 1em 0;
}
a:hover {
	text-decoration: none;
}

.tab-content > .active {
	border-left: solid 1px #dee2e6;
	border-right: solid 1px #dee2e6;
	border-bottom: solid 1px #dee2e6;
}

.file-table {
	overflow-x:auto;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
	width: 100%;
	border: 0;
}

th, td {
	text-align: left;
	padding: 8px;
}

tr:nth-child(even){
	background-color: #f2f2f2
}


#students-walking {
    background: url(../images/_SJP0825.JPG) no-repeat center center;
    background-size: 150%;
}
.subheading-border {
 	/*width: 100%;*/
 	border-bottom: solid 2px #A90533;
}
.subheading-border>h2 {
	white-space: nowrap;
	font-family: 'Outfit', Arial, Helvetica, sans-serif;
	font-weight: 700;
	font-size: 40px;
	margin: .25em 10px;
	color: #111111;
}
.header-fill {
	opacity: .85;
}
.banner-image {
	width: 100%;
	overflow: hidden;
	height: calc(100vh - 124px);
	position: fixed;
	z-index: -10;
}

.bg-img {
	height: 100%;
	object-fit: cover;
	object-position: center center;
}

.bg-height {
	height: calc(100vh - 124px);
}
.main-body {
	position: absolute;
	left: calc(300px + 4px);
	width: calc(100% - 300px - 4px);
	overflow: hidden;
}
#banner-image {
	background-image: url("../ROXY/IMG_7587.JPG");
	background-position: center center;
	background-size: cover;
	-webkit-transition: background-image 1.5s linear;
	-moz-transition: background-image 1.5s linear;
	-o-transition: background-image 1.5s linear;
	-ms-transition: background-image 1.5s linear;
	transition: background-image 1.5s linear;
}


#students {
	background: url("../img/IMG_5018.JPG") center center;
	background-size: cover;
}
#ruok {
	background: url("../img/maxresdefault.jpg") center center;
	background-size: cover;
}

.fam-sup-logo {
	max-width: 450px;
	width: 100%;
	margin-top: 30px;
}

a .square, .square h4 {
	color: black !important;
}
.square {
	height: 200px;
	background-color: #A90533;
	margin: 20px 0;
	-webkit-transition: transform .2s;
	-moz-transition: transform .2s;
	-ms-transition: transform .2s;
	-o-transition: transform .2s;
	transition: transform .2s;
}
.square .background-img {
	height: 100%;
	-webkit-transition: opacity .2s;
	-moz-transition: opacity .2s;
	-ms-transition: opacity .2s;
	-o-transition: opacity .2s;
	transition: opacity .2s;
}
.square:hover .background-img {
	opacity: .2;
}
.square h4 {
	opacity: 0;
	position: absolute;
	text-align: center;
	top: 50%;
	transform: translate(-50%, -50%);
	transition: opacity .2s ease-in;
	left: 50%;
}
.square:hover {
	cursor: pointer;
	transform: scale(1.1);
}
.square:hover h4 {
	opacity: 1;
}

.square.no-background {
	background-color: #FFFFFF !important;
	cursor: default;
	transform: scale(1.0);
}

.mt30 {
	margin-top: 30px;
}
.mt10 {
	margin-top: 10px;
}

.bold {
	font-weight: bold;
}

/* -- SAFARI FIX -- */

.cke_skin_kama span.cke_browser_webkit,.cke_skin_kama span.cke_browser_gecko18 {
	outline: none !important;
}

/* -- HOME CONTENT --*/

.home {
	height: calc(100vh - 120px + 4px);
	width: 100%;
}
.home-footer {
	position: relative;
	top: 95%;
	height: 5vh;
	-webkit-transform: translate(0, -100%);
	-ms-transform: translate(0, -100%);
	-moz-transform: translate(0, -100%);
	-o-transform: translate(0, -100%);
	transform: translate(0, -100%);
}
.home-footer.ios {
	top: 85%;
}

.outer-scroll {
	position: relative;
	float: right;
	width: 3.25vh;
	height: calc(100% - 4px);
	border: solid white 2px;
	border-radius: 10vh;
}
.outer-scroll:hover {
	cursor: pointer;
}
.inner-scroll {
	position: relative;
	width: 10%;
	height: 10%;
	left: 50%;
	-webkit-transform: translate(-50%);
	-ms-transform: translate(-50%);
	-moz-transform: translate(-50%);
	-o-transform: translate(-50%);
	transform: translate(-50%);
	top: 45%;
	border-radius: 20px;
	background-color: white;
	animation: scroll 2s ease-in infinite;
}
@keyframes scroll {
	25% {top: 10%;height:45%;width:10%;}
	50% {top: 10%; height: 10%;opacity:1;}
	55% {opacity: 0;}
	100% {opacity: 0;}
}
@-webkit-keyframes scroll {
	25% {top: 10%;height:45%;width:10%;}
	50% {top: 10%; height: 10%;opacity:1;}
	55% {opacity: 0;}
	100% {opacity: 0;}

}

/* -- MOBILE MODIFICATIONS --*/

.mobile-upper {
	position: relative;
	height: 4px;
	width: 100%;
	background-color: white;
	border-bottom: white solid 2px;
}
.mobile-lower {
	position: relative;
	height: 4px;
	width: 100%;
	background-color: white;
	border-top: white solid 2px;
}

/* -- FOOTER -- */

footer {
	background-color: #111111;
}

.footer-content
{
	padding: 4em 16.666% 0;
	position: relative;
	color: #ffffff;
	padding-bottom: 50px
}

.footer-body {
	padding-bottom: 50px;
}

.footer-body a
{
	color: #6D6E71
}

.footer-body a:hover
{
	color: #ffffff;
}

.footer-body img {
	padding-bottom: 30px;
}

.copywrite
{
	border-top: 1px solid rgba(153, 153, 153, 0.15);
	width: 100%;
	padding-top: 50px;
}

.footer-main {
	width: 50%;
	height: 100%;
	float: left;
	font-family: 'Outfit', Arial, Helvetica, sans-serif;
	font-weight: 400;
	font-size: 12px;
}
.footer-break {
	position: relative;
	height: 100%;
	width: 100%;
	left: 16.665%;
}
.icon-links {
	position: relative;
	width: 100%;
	height: 50%;
}
.icon-links>a {
	height: 100%;
	max-height: 40px;
	margin-right: 1em;
	text-decoration: none;
	float: left;
}
.icon-links>a>img {
	height: 100%;
}



/* -- MEDIA QUERIES -- */

@media only screen and (max-width: 1133px) {
	.heading-border.inc-sub>h3, .heading-border.inc-sub>h4 {
		display: none;
	}
}

/* -- IPAD HORIZONTAL -- */
@media only screen and (max-width: 991px) {
	.header {
		overflow: visible;
	}
	.header .dropdown-item {
		text-align: center;
	}
	.header .navbar {
		padding-bottom: 5px;
	}
	.header .dropdown-menu {
		-webkit-box-shadow: none;
		-moz-box-shadow: none;
		box-shadow: none;
	}
	.nav-btn-wrap {
		display: block;
	}
	.nav-heading, .footer-main, .intext-img{
		width: 100%;
	}
	.nav-heading {
		height: auto;
		clear: both;
		padding: 10px 0;
	}
	/*
	.nav-heading:nth-last-child(1) {
		border-bottom: solid 4px #96D6D3;
	}*/
	.nav-headings {
		top: 0;
		transform: none;
		height: auto;
	}
	.outer-scroll {
		border-radius: 4px;
		width: 3vh;
		border-bottom: solid white .8vh;
		border-top: solid white .8vh;
		height: calc(100% - 1.6vh);
	}
	.footer-break {
		left: 8px;
		width: 92%;
	}
	.outer-scroll {
		width: 4.5vh
	}
	.icon-links {
		padding-top: 1vh;
		width: 100%;
		height: 80%;
	}
	.text-content {
		padding: 4.13vh 0;
	}
	.page-heading {
		font-size: 51.2px;
	}
	.break-quote {
		font-size: 20px;
	}
	.heading-border.sub-border {
		width: 100%;
	}
	.subheading-border {
		border-bottom: none;
		border-top: solid 2px #A90533;
		margin:4em 0 0 4em;
		width: calc(100% - 4em);
	}
	.subheading-border>h2 {
		white-space: normal;
	}
}

/* -- FOR MOBILE -- */
@media only screen and (max-width: 736px) {

	.navbar-toggler {
		display: block !important;
	}

	.header, .main-body {
		width: calc(100% - 89px) !important;
		left: 89px;
	}
	.header>.navbar-container {
		width: 100%;
	}
	.logo-cont {
		height: calc(120px - 4px);
	}
	.header-left {
		/*display: none;*/
		z-index: 100;
	}
	.main-body {
		width: calc(100% - 89px);
		left: 89px;
	}
	.content-body {
		width: 100%;
		left: 0;
	}
	.page-heading {
		font-size: 45px;
	}
	.small-break, .break-quote {
		display: none;
	}
	.subheading-border {
		margin: 4em 0 0 0;
		width: 100%;
	}
}