/**** TOC ****

1. Global
2. Header
3. Top Nav
4. Page Layout
5. Sidebar Accordion Nav
6. Sidebar (Right side)
7. Typography
8. Callout
9. Image alignment
10. Footer
11. Buttons
12. Tables
13. Accordion - On Page

****/


/* 1. GLOBAL */

body {
    color: #000;
    font-family: 'proxima-nova', sans-serif;
    font-size: 16px;
    line-height: 26px;
}

img {
    max-width: 100%;
}

a {
    color: #0095AF;
}

a:hover {
    color: #0095AF;
    text-decoration: underline;
}

.nav__sidebar a.active {
	color: #00709C;
}

ul li,
ol li {
    margin-bottom: 12px;
}

/* alphaNav */

.listNav { margin:0 0 10px;}

.ln-letters { overflow:hidden; }
.ln-letters a { font-size:0.9em; display:block; float:left; padding:2px 5px; border:1px solid silver; border-right:none; text-decoration:none; }
.ln-letters a.ln-last { border-right:1px solid silver; }
.ln-letters a:hover,
.ln-letters a.ln-selected { background-color:#eaeaea; }
.ln-letters a.ln-disabled { color:#ccc; }
.ln-letter-count { text-align:center; font-size:0.8em; line-height:1; margin-bottom:3px; color:#336699; }

#myList {
  margin: 20px 0;
  list-style-type: none;
}
#myList li {
  margin-bottom: 15px;
}

.page-link {
    position: relative;
    display: block;
    padding: .5rem .75rem;
    margin-left: -1px;
    line-height: 1.25;
    color: #005cb8;
    background-color: #fff;
    border: 1px solid #F7F5F0;
}

.page-item.active .page-link {
    z-index: 1;
    color: #fff;
    background-color: #005cb8;
    border-color: #005cb8;
}

.page-link:hover {
    z-index: 2;
    color: #0095AF;
    text-decoration: none;
    background-color: #F7F5F0;
    border-color: #F7F5F0;
}

.breadcrumb {
	background-color: transparent;
	padding: 0;
	margin-bottom: 30px;
}

.breadcrumb-item+.breadcrumb-item::before {
    display: inline-block;
    padding-right: .5rem;
    color: #707070;
    content: "|";
}

.breadcrumb-item, .breadcrumb-item.active {
    color: #707070;
}

/* 2. HEADER */
.header__main {
    /*background-image: url(../img/segal-header-small.png);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: 50% 50%;
    height: 0;
    padding-top: 53.88%;*/
    border: 10px solid #ffffff;
    position: relative;
    /* margin-bottom: 20px; */
    width: 100%;
}

@media (max-width: 991px){
	.header__main {
		margin-top: 50px;
	}
	
	.navbar-light .navbar-toggler {
		background-color: #1dcad3;
    	color: #ffffff;
    	border-color: #1dcad3;
	}
	
	.navbar-collapse.collapse.show > ul.navbar-nav {
		display: none;
	}
	
	.navbar.navbar-light.navbar-expand-lg {
    	background: #1dcad3;
	}
}

@media (min-width: 550px) {
    .header__main {
        /* background-image: url(../img/segal-header-medium.png);
        padding-top: 10%;
        margin-bottom: 0; 
		background-color: #1dcad3;*/
    }
}

@media (min-width: 992px) {
   /* .header__main {
        background-image: url(../img/segal-header.png);
        padding-top: 25.85%;
        margin-bottom: 0;*/
    }
}

.header__main__actions {
    position: relative;
    display: flex;
    width: calc(100% + 30px);
    margin-left: -15px;
}

@media (min-width: 800px) {
    .header__main__actions {
        position: absolute;
        top: 23%;
        right: 0;
        margin-left: auto;
        width: auto;
    }
}

@media (min-width: 992px) {
    .header__main__actions {
        position: absolute;
        top: 20%;
        right: 0;
        margin-left: auto;
        width: auto;
    }
}

@media (min-width: 1100px) {
    .header__main__actions {
        top: 20%;
    }
}

.header__main__actions .action__enroll,
.header__main__actions .action__search {
    width: 50%;
}

.header__main__actions .action__search .form-inline {
    flex-flow: row;
}

.header__main__actions .action__search .form-group {
    display: flex;
    flex: 1 1 auto;
}

@media (min-width: 992px) {
    .header__main__actions .action__enroll,
    .header__main__actions .action__search {
        width: auto;
    }
}

.header__main__actions a {
    margin-right: 20px;
}

/*.header__main input.form-control[type="text"] {
    border: none;
    border-radius: 0;
    background-color: #F7F5F0;
    padding-top: 10px;
    padding-bottom: 10px;
    height: auto;
    width: 100%;
}
*/
.header__main .btn-submit {
    border-radius: 0;
    background-color: #001c71;
	color: #fff;
    /*padding-top: 9px;
    padding-bottom: 9px;
    width: 42px;*/
} 


/* 3. TOP NAV */



.navbar {
    padding: 0;
    justify-content: flex-end;
}

.navbar .nav__sidebar {
    width: 100%;
}

.nav__main {
    position: absolute;
    top: 0;
    width: 100%;
	z-index: 1000;
}

@media (min-width: 992px) {
    .nav__main {
        background-color: #001c71;
        position: relative;
        width: auto;
    }
}

.nav__main .content__main {
    padding: 0;
    width: 100%;
}

@media (min-width: 992px) {
    .nav__main .content__main {
        width: auto;
    }
}

.nav__main .nav__spacer {
    border-right: 1px solid rgba(255,255,255,.31);
    width: 308px;
    flex: 0 0 auto;
}

.nav__item {
    padding-left: 25px;
    padding-right: 25px;
    margin-bottom: 0;
    border-bottom: 1px solid #DDCB97;
}


.nav__item:first-of-type {
    border-left: 0;
}

.nav__item:last-of-type {
    border-bottom: 2px solid #BE9B39;
}

@media (min-width: 992px) {
    .nav__item {
        border-left: 1px solid rgba(255,255,255,.31);
        border-bottom: none;
        padding-left: 40px;
        padding-right: 40px;
    }
    .nav__item:last-of-type {
        border-right: 1px solid rgba(255,255,255,.31);
        border-bottom: none;
    }
}

.nav__main a {
    display: block;
    color: #000;
    text-transform: uppercase;
    font-family: "proxima-nova-condensed",sans-serif;
    font-weight: 700;
    font-size: 18px;
    line-height: 22px;
    padding-top: 15px;
    padding-bottom: 15px;
    text-decoration: none;
}

.nav__main a:hover {
    color: #D9EAF0;
}

@media (min-width: 992px) {
    .nav__main a {
        text-align: center;
        color: #ffffff;
    }
}

.navbar-toggler {
    border: none;
    width: 100%;
    border-radius: 0;
}

.navbar-toggler[aria-expanded='true'] {
    /*background-color: #E2E1D4;*/
}

.navbar-light .navbar-toggler-icon {
    display: block;
    float: right;
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(0, 0, 0, 1)' stroke-width='3' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E")
}

.navbar-collapse {
    align-items: flex-start;
}

.navbar-collapse {
    /*background-color: #E2E1D4;*/
}

@media (min-width: 992px) {
    .navbar-collapse {
        background-color: transparent;
    }
}

/* 4. PAGE LAYOUT */

.page__wrap {
    flex-flow: column;
}

@media (min-width: 768px) {
    .page__wrap {
        flex-flow: row;
    }
}

.nav__sidebar {
    width: 308px;
    flex: 0 0 auto;
}

.page__wrap .nav__sidebar {
    background: #1dcad3;
	min-height: calc(100vh);
}

.content__main__wrap {
    width: 100%;
    padding: 50px 20px;
    display: flex;
    flex-flow: column;
}


@media (min-width: 800px) {
    .content__main__wrap {
        padding: 20px 20px;
        flex: 1 1 auto;
        flex-flow: row;
    }
}

@media (min-width: 992px) {
    .content__main__wrap {
        padding: 50px 35px 50px 60px;
        flex-flow: column;
    }
}

@media (min-width: 1024px) {
    .content__main__wrap {
        flex-flow: row;
    }
}

.content__main__body {
    flex: 1;
}

@media (min-width: 800px) {
    .content__main__body {
        padding-right: 50px;
    }
}

.content__sidebar {
    width: 100%;
}

@media (min-width: 769px) {
    .content__sidebar {
        max-width: 240px;
        margin-top: 108px;
    }
}


/* 5. SIDEBAR ACCORDION NAV */

.nav__sidebar .card,
.nav__sidebar .card-header:first-child {
    border-radius: 0;
}

.nav__sidebar .card {
    background-color: rgba(255,255,255,.45);
    border: none;
}

.nav__sidebar .card-header {
    padding-top: 0;
    padding-left: 40px;
    padding-right: 30px;
}

.nav__sidebar .card-header {
    padding: 0;
    background-color: #1dcad3;
    border-bottom: none;
}

.nav__sidebar .btn {
    width: 100%;
    background-color: transparent;
    text-align: left;
    padding-top: 15px;
    padding-bottom: 15px;
    padding-left: 25px;
    padding-right: 25px;
    font-size: 18px;
    line-height: 22px;
    position: relative;
    border: none;
    outline: inherit;
    border-radius: 0;
    text-transform: none;
    font-family: 'proxima-nova', sans-serif;
    font-weight: 100;
}

.nav__sidebar .card-body {
    padding-left: 25px;
    padding-top: 0;
}

.subNode {
	padding-left: 8px;
	margin-bottom: 0px;
}

.sub-subNode {
	padding-left: 16px;
}

.nav__sidebar__submenu .sub-subNode a {
	font-size: 13px;
}

.nav__sidebar__submenu li.subNode a,  .nav__sidebar__submenu li.subNode{
	font-size: 14px;
}

@media (min-width: 992px) {
    .nav__sidebar .btn {
        padding-top: 26px;
        padding-bottom: 26px;
        padding-left: 40px;
    }

    .nav__sidebar .card-body {
        padding-left: 40px;
    }
}

.nav__sidebar a.btn {
    color: #000;
    border-bottom: 1px solid #001c71;
    border-radius: 0;
}

.nav__sidebar .btn:after {
    position: absolute;
    right: 30px;
    margin-top: 5px;
}

.nav__sidebar .btn[aria-expanded='false']:after {
    content: '';
    height: 10px;
    width: 10px;
    border-style: solid;
    border-color: #000;
    border-width: 0px 2px 2px 0px;
    transform: rotate(45deg);
}

.nav__sidebar .btn[aria-expanded='true'] {
    background: rgba(255,255,255,.45);
    font-weight: 700;
}

.nav__sidebar .btn[aria-expanded='false'] {
    border-bottom: 1px solid #005cb8;
    border-radius: 0;
}

.nav__sidebar .btn[aria-expanded='true']:after {
    content: '';
    height: 10px;
    width: 10px;
    border-style: solid;
    border-color: #000;
    border-width: 0px 2px 2px 0px;
    transform: rotate(-135deg);
}

.nav__sidebar__submenu a {
    color: #000;
    font-size: 16px;
    line-height: 20px;
    text-transform: none;
    font-weight: normal;
    font-family: 'proxima-nova', sans-serif;
    font-weight: 100;
    padding-bottom: 5px;
}

.nav__sidebar__submenu a:hover {
    color: #0095AF;
    text-decoration: none;
}

.nav__sidebar__submenu li {
    margin-bottom: 0;
}

@media (min-width: 992px) {
    .nav__sidebar__submenu li {
       margin-bottom: 10px;
    }
}

/* 6. SIDEBAR (Right side) */

.menu__sub {
    border-top: 3px solid #001c71;
    padding-top: 15px;
}

.menu__sub h2 {
    font-size: 18px;
    line-height: 22px;
    margin-bottom: 20px;
}

.menu__sub ul {
    border-top: 1px solid #001c71;
    border-bottom: 1px solid #001c71;
    padding: 15px 5px;
}

.menu__sub li {
    font-size: 15px;
    line-height: 20px;
    margin-bottom: 10px;
}

.menu__sub li a {
    text-decoration: none;
    color: #000000;
}

.menu__sub li a:hover {
    color: #0095AF;
}

.menu__sub li a:after {
    content: ' >';
    color: #BE9B39;
}

/* 7. TYPOGRAPHY */

h1.page__title {
    color: #001c71;
    font-size: 24px;
    line-height: 30px;
    /*text-transform: uppercase;*/
    font-family: linotype-sabon, Palatino, Palatino Linotype, Palatino LT STD, Book Antiqua, Georgia, serif;
    font-weight: 700;
}

@media (min-width: 768px) {
    h1.page__title {
        font-size: 32px;
        line-height: 36px;
    }
}

h2.heading2 {
    font-size: 18px;
    line-height: 28px;
    font-family: "droid-serif",serif;
    margin-bottom: 20px;
    font-style: italic;
}

@media (min-width: 768px) {
    h2.heading2 {
        font-size: 20px;
        line-height: 30px;
    }
}

h3.heading3 {
    font-size: 18px;
    line-height: 22px;
    font-weight: 600;
    margin-bottom: 20px;
    padding-top: 20px;
}

@media (min-width: 768px) {
    h3.heading3 {
        font-size: 17px;
        line-height: 20px;
    }
}

/* 8. CALLOUT */

.callout {
    background-color: #c7cad1;
    padding: 30px 15px;
    margin-bottom: 35px;
    clear: both;
}

.callout img {
    margin-bottom: 20px;
    max-width: 150px;
}

@media (min-width: 768px) {
    .callout img {
        margin-bottom: 20px;
        max-width: 100%;
    }
}

/* 9. IMAGE ALIGNMENT */

.image__left {
    margin-bottom: 20px;
}

.image__right {
    margin-bottom: 20px;
}

@media (min-width: 768px) {

    .image__left {
        float: left;
        margin: 0 35px 10px 0;
        max-width: 300px;
    }

    .image__right {
        float: right;
        margin: 0 0 10px 35px;
        max-width: 300px;
    }

}

/* 10. FOOTER */

.page__footer {
    font-size: 12px;
    line-height: 15px;
    color: #686766;
    display: flex;
    flex-flow: column;
    border-top: 1px solid #C1C1C1;
    padding-top: 35px;
    margin-bottom: 30px;
}

@media (min-width: 768px) {
    .page__footer {
        flex-flow: row;
    }
}


.page__footer_icon {
    width: 85px;
    margin-right: 27px;
    margin-bottom: 28px;
}

.page__footer_text {
    flex: 1;
}

/* 11. BUTTONS */

.btn-link {
    font-family: "proxima-nova-condensed",sans-serif;
    font-weight: 700;
    position: relative;
    color: #C5992F;
    background-color: #F2EAD7;
    border-radius: 0;
    margin-bottom: 35px;
    font-size: 18px;
    line-height: 22px;
    text-transform: uppercase;
    padding: 14px 55px 10px 25px;
    text-align: left;
    width: 100%;
}

@media (min-width: 768px) {
    .btn-link {
        width: auto;
        margin-right: 35px;
    }
}

.btn-link:hover {
    background-color: #BE9B39;
    color: #ffffff;
    text-decoration: none;
}

.btn-link:hover:after {
    border-color: #ffffff;
}

.btn-link:after {
    content:'';
    position: absolute;
    right: 13px;
    display: inline-block;
    height: 16px;
    width: 16px;
    border-style: solid;
    border-color: #C5992F;
    border-width: 0px 5px 5px 0px;
    transform: rotate(-45deg);
}

.btn.btn-outline {
    border: 4px solid #BE9B39;
    text-transform: uppercase;
    border-radius: 0;
    color: #BE9B39;
    font-family: "proxima-nova-condensed",sans-serif;
    font-weight: 700;
    display: block;
}

@media (min-width: 550px) {
    .btn.btn-outline {
        padding-left: 35px;
        padding-right: 35px;
    }
}

@media (min-width: 992px) {
    .btn.btn-outline {
        padding-left: 57px;
        padding-right: 57px;
    }
}

/* 12. TABLES */

table {
    font-size: 14px;
    line-height: 23px;
}

table#formsDocsTable ul {
	padding-left: 0;
	list-style: none;
	margin-bottom: 0;
}

table#formsDocsTable ul li:last-child {
	margin-bottom: 0;
}

@media (min-width: 768px) {
    table {
        font-size: 16px;
        line-height: 26px;
    }
}

.table thead th {
    background-color: #001c71;
    color: #fff;
}

.table thead th,
.table td,
.table th {
    border: 1px solid #ddd;
}

.table tbody tr:nth-child(even) {
    background-color: #fff;
}

.table-striped tbody tr:nth-of-type(odd) {
    background-color: #f9f9f9;
}

/* 13. ACCORDION - ON PAGE */

.accordion__interior button {
    width: 100%;
    text-align: left;
    border: none;
    background-color: #e65300;
    color: #ffffff;
    display: flex;
    align-items: center;
    padding-top: 10px;
    padding-bottom: 10px;
    padding-left: 30px;
    padding-right: 50px;
    cursor: pointer;
    font-weight: 700;
    position: relative
}

.accordion__interior button:focus {
    outline: none;
}

.accordion__interior button[aria-expanded="true"]:after {
    content: "\2013";
    position: absolute;
    right: 16px;
    font-size: 40px;
    top: -5px;
}

.accordion__interior button[aria-expanded="false"]:after {
    content: "+";
    position: absolute;
    right: 16px;
    font-size: 40px;
    top: 0;
}

.accordion__interior .card {
    border: none;
    margin-bottom: 20px;
}

.accordion__interior .card-header {
    padding: 0;
    border: none;

}

.vcard {
  	background-color: #1DCAD3;
  	color: #fff;
  	padding: 1rem;
	height: 5rem;
	text-align: center;
	text-decoration: none;
	font-size: 0.79em;
	line-height: 14px;
}

.vcard:hover {
	text-decoration: none;
	color: #fff;
	background-color: #001C71;
}

.vcards {
  	max-width: 1200px;
	margin: 0 auto;
  	display: grid;
  	grid-gap: 1rem;
}

/* Screen larger than 600px? 2 column */
@media (min-width: 600px) {
  .vcards { grid-template-columns: repeat(2, 1fr); }
}

/* Screen larger than 900px? 3 columns */
@media (min-width: 900px) {
  .vcards { grid-template-columns: repeat(3, 1fr); }
}