@charset "utf-8";

/* 
|| CONTENTS
|| - GLOBAL VARIABLES
|| - GENERAL STYLES
|| - - TYPOGRAPHY
|| - ICONS
|| - OBJECTS
|| - COMPONENTS
|| - - button
|| - - iframe scaler
|| - ICONS
|| - HEADER
|| - NAVIGATION
|| - - MAIN MENU
|| - - - SEARCH
|| - - BREADCRUMB
|| - - MOBILE MENU
|| - - - MOBILE MENU CLOSE
|| - PAGES
|| - - HOMEPAGE
|| - - CONTACT DIRECTORIES
|| - - - CONTACT PAGES
|| - UTILITY CLASSES
|| - MEDIA QUERIES
*/
/* 
|| - GLOBAL VARIABLES  
*/
body {
  /*  || COLORS  */
  /*  || Brand Colors  */
  --clr__blue-main: rgb(26, 45, 93);
  --clr__blue_main: var(--clr__blue-main);
  --clr__teal: rgb(123, 204, 195);
  --clr__teal-100: rgb(123, 204, 195);
  --clr__teal-200: rgb(107, 185, 177);
  --clr__teal-300: rgb(91, 166, 159);
  --clr__teal-400: rgb(75, 147, 141);
  --clr__teal-500: rgb(59, 128, 123);
  --clr__teal-600: rgb(53, 114, 109);
  --clr__teal-700: rgb(47, 100, 95);
  --clr__teal-800: rgb(38, 85, 80);
  --clr__teal-900: rgb(29, 71, 66);
  --clr__blue_secondary: var(--clr__teal);
  --clr__blue_dark: rgb(42, 66, 115);
  --clr__blue_green: rgb(166, 222, 219);
  --clr__green-accent: rgb(132, 196, 71);
  --clr__orange: rgb(248, 149, 61);
  --clr__magenta-accent: var(--clr__orange);
  --clr__magenta-100: rgb(255, 199, 229);
  --clr__offwhite_main: rgb(243, 244, 244);
  --clr__white-accent: rgb(255, 255, 255);
  --clr__white-100: rgb(238, 238, 238);
  --clr__yellow: rgb(255, 208, 110);
  /* || Auxilliary Colors */
  --clr__grey: rgb(233, 236, 239);
  --clr__grey-100: rgb(51, 51, 51);
  --clr__black_rich: rgb(32, 32, 32);
  --clr__black_secondary: rgb(38, 38, 38);
  /* || Background Colors */
  --clr-bg__white-transparent: rgba(255, 255, 255, 0.86);
  --clr-bg__navy-transparent: rgba(44, 61, 110, 0.9);
  --clr-bg__white: rgb(238, 238, 238);
  --clr-bg__white-accent: var(--clr__white-accent);
  --clr-bg__navy: var(--clr__blue_main);
  --clr-bg__magenta-accent: var(--clr__magenta-accent);
  --clr-bg__green-accent: var(--clr__green-accent);
  /* || Magic numbers/Measurements */
  /*	|| Background for image captions */
  --img-caption__bg: rgb(0, 0, 0);
  --img-caption__bg-start: linear-gradient(
    146deg,
    rgba(0, 0, 0, 0.908000700280112) 34%,
    rgba(0, 0, 0, 0) 66%
  );
  --img-caption__bg-end: linear-gradient(
    160deg,
    rgba(0, 0, 0, 0.908000700280112) 66%,
    rgba(0, 0, 0, 0) 90%
  );
  /*  || Transition timings  */
  --time__transition-delay: 0s;
  --time__transition-duration: 0.4s;
  --transition__standard: all var(--time__transition-duration) ease-in;
  /* || Fonts */
  --font__accent: Garamond, Baskerville, Baskerville Old Face, Hoefler Text,
    Times New Roman, serif;
  --font__main: "tk-futura-pt-n4", "futura-pt", sans-serif;
}

/* bs overrides */
:root {
  --bs-primary-rgb: rgb(26, 45, 93);
}

.smf blockquote {
  margin: revert;
  font-style: oblique;
}

.smf blockquote em {
  font-style: normal;
}

/*
|| - GENERAL STYLES
*/
@media (max-width: 1199px) {
  .logo-image {
    height: 65px;
  }
}

.smf #sp-main-body {
  background-color: var(--clr__blue_main);
}

.smf:not(.com_rsform) #sp-main-body .container {
  background-color: var(--clr__white-accent);
}

.smf.view-login #sp-main-body .container {
  background-color: var(--clr__offwhite_main);
}

#sp-header {
  background-color: var(--clr__blue_main);
}

#sp-header.header-sticky .logo a {
  margin-top: 10px;
}

.smf .white-popup-block {
  overflow: auto !important;
}

.smf #page-title {
  background-color: var(--clr__magenta-accent);
}

.smf #page-title h1 {
  color: var(--clr__white-accent);
}

.smf #page-title .sppb-addon-wrapper + .sppb-addon-wrapper {
  color: var(--clr__blue_dark);
}

.smf #page-title .sppb-addon-wrapper + .sppb-addon-wrapper .sppb-addon-title {
  text-shadow: none;
  padding-left: 1em;
}

.page-content section:not(#page-title) .sppb-row-container {
  padding-inline: 45px;
}

.smf #sp-bottom {
  background-color: var(--clr__teal);
  color: var(--clr__blue_main);
}

.smf #sp-bottom a {
  color: var(--clr__blue_main);
  text-decoration: underline;
}

.smf #sp-bottom .container {
  background-color: transparent;
}

.smf iframe body {
  padding-block: 5em;
  padding-inline: 2em;
}

/* 
|| - - TYPOGRAPHY 
*/
body {
  font-family: var(--font__main);
  font-weight: 300;
  font-style: normal;
  font-size: 18px;
}

h1 {
  font-family: var(--font__accent);
}

.smf h2 {
  text-transform: uppercase;
  letter-spacing: 0px;
}

#nav-shortcuts {
  font-family: "Futura PT", sans-serif;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.sp-contact-info li {
  font-size: 1em;
}

.smf #page-title .sppb-addon-wrapper + .sppb-addon-wrapper .sppb-addon-title {
  font-size: 1.4em;
}

/*
|| - OBJECTS
*/
/* buttons */
.smf .sppb-btn.sppb-btn-custom {
  text-transform: uppercase;
  font-weight: bold;
  font-size: 0.9em;
  letter-spacing: 1px;
  border-radius: 0;
}

.smf .sppb-btn.sppb-btn-custom.smf-standard {
  font-size: 23.4px !important;
  font-weight: 300 !important;
}

.sppb-btn-secondary {
  color: #fff;
  transition: all 250ms ease;
  background-color: var(--clr__blue_dark);
  border-color: var(--clr__blue_dark);
}

.sppb-btn-secondary:hover {
  background-color: var(--clr__blue_main);
  border-color: var(--clr__blue_main);
}

/* previous faculty subheader button */
/* !important is needed for all rules to ovverride specificity of inline styling */
.smf .faculty .sppb-btn-custom {
  padding: 1em !important;
  margin-bottom: 1em !important;
  background-color: transparent !important;
  color: var(--clr__black-secondary) !important;
  border-radius: 0px !important;
  border-top: none !important;
  border-right: 1px solid var(--clr__grey) !important;
  border-bottom: 1px solid var(--clr__grey) !important;
  border-left: none !important;
  position: relative;
  top: -1px;
}

.smf .faculty .sppb-btn-custom:hover,
.smf .faculty .sppb-btn-custom:focus,
.smf .faculty .sppb-btn-custom:active {
  background-color: var(--clr__grey) !important;
}

.smf .faculty .sppb-btn-custom::before {
  content: "";
  display: block;
  position: absolute;
  left: -5px;
  width: 5px;
  height: 0px;
  background-color: transparent;
  transition: var(--transition__standard);
}

.smf .faculty .sppb-btn-custom:hover::before {
  background-color: var(--clr__blue_main);
  height: 54.09px;
}

/*
|| iframe scaler
*/
@media screen and (max-width: 900px) {
  .mfp-iframe-scaler {
    width: 90vw;
    padding-top: 80vh;
  }
}

/*
|| testimonial
*/
.smf .testimonial img {
  height: 250px;
  width: auto;
}

/* 
|| - COMPONENTS
*/
/* 
|| - - FORMS
*/
.smf.com_rsform h2 {
  text-align: center;
}

.smf.com_rsform h3 {
  font-weight: bold;
  text-align: center;
  text-transform: uppercase;
}

.smf.com_rsform h4 {
  font-weight: bold;
  font-size: 1em;
  text-transform: uppercase;
}

.smf.com_rsform .formContainer {
  background-color: var(--clr-bg__white-accent);
  border-radius: 0 0 25px 0;
  padding: 2em;
}

/*
|| - HEADER
*/
#sp-header {
  /*	!important is necessary to override template default */
  height: 120px !important;
  padding-top: 10px !important;
}

/* 
|| - NAVIGATION 
*/
.sp-megamenu-parent > .sp-menu-item > a {
  color: var(--clr__white-accent);
  text-transform: lowercase;
  /*	!important is necessary to override template default */
  font-size: 1.3em !important;
}

/*
|| - - MAIN MENU
*/
/* #sp-menu .sp-megamenu-parent>.sp-menu-item:nth-last-child(2) {
  border-right: 1px solid var(--clr__offwhite_main);
  padding-right: 1em;
} */

.sp-menu-item * {
  text-transform: lowercase !important;
}

body.ltr .sp-megamenu-parent > li.sp-has-child > a:after,
body.ltr .sp-megamenu-parent > li.sp-has-child > span:after {
  font-family: unset;
  float: unset;
  margin-left: unset;
  content: "➤";
  display: inline-block;
  position: relative;
  right: -3px;
  font-weight: 100;
  font-size: 0.6em;
  opacity: 0.5;
  transform: none;
  transition: transform;
  transition-delay: var(--time__transition-delay);
  transition-duration: var(--time__transition-duration);
}

/* final button */
#sp-menu
  .sp-megamenu-parent
  > li.sp-menu-item:last-child
  > a.btn-menu-highlight {
  background-color: var(--clr__magenta-accent);
  padding: 15px;
  margin: 15px;
  line-height: 1em;
}

#sp-menu
  .sp-megamenu-parent
  > li.sp-menu-item:last-child:hover
  > a.btn-menu-highlight,
#sp-menu
  .sp-megamenu-parent
  > li.sp-menu-item:last-child:active
  > a.btn-menu-highlight {
  background-color: transparent;
}

body.ltr .sp-megamenu-parent > li.sp-has-child:hover > a:after,
body.ltr .sp-megamenu-parent > li.sp-has-child:hover > span:after,
body.ltr .sp-megamenu-parent > li.sp-has-child:active > a:after,
body.ltr .sp-megamenu-parent > li.sp-has-child:active > span:after,
body.ltr .sp-megamenu-parent > li.sp-has-child:focus > a:after,
body.ltr .sp-megamenu-parent > li.sp-has-child:focus > span:after {
  transform: rotate(90deg);
}

.smf .sp-megamenu-parent .sp-dropdown li.sp-menu-item > a {
  font-size: 18px;
  color: var(--clr__blue_dark);
}

.smf .sp-megamenu-parent .sp-dropdown li.sp-menu-item.active > a {
  color: var(--clr__blue_main);
}

.smf .sp-megamenu-parent .sp-dropdown li.sp-menu-item:hover > a {
  color: var(--clr__magenta-accent);
}

/* || - - SEARCH */
/* hide search */
.smf nav + .header-modules {
  display: none !important;
}

/* search input */
#mod-finder-searchword0 {
  border: 0;
  text-transform: lowercase;
  /*	!important is necessary to override template default */
  font-size: 1.3em !important;
}

/* || - MOBILE MENU */
@media (min-width: 992px) {
  #offcanvas-toggler {
    display: none !important;
  }
}

@media (max-width: 992px) {
  .logo-image-phone {
    height: 63px;
  }
}

@media (max-width: 576px) {
  .logo-image-phone {
    height: 75px;
  }
}

#offcanvas-toggler .burger-icon span {
  background-color: var(--clr__white-accent);
}

.offcanvas-menu {
  width: 100vw;
}

body.ltr.offcanvs-position-right .offcanvas-menu {
  right: -100vw;
}

.offcanvas-menu .offcanvas-inner {
  display: flex;
  flex-direction: column-reverse;
}

.offcanvas-menu .offcanvas-inner ul.nav-pills > li {
  border-bottom: 1px solid var(--clr__grey-100);
  padding-top: 5px;
  padding-bottom: 5px;
}

.offcanvas-menu .sp-module.offcanvas-menu-logo-container {
  width: 100vw;
  position: relative;
  top: -41px;
  left: -41px;
}

.offcanvas-menu
  .offcanvas-inner
  ul.menu
  > li.menu-parent
  > a
  > span.menu-toggler,
.offcanvas-menu
  .offcanvas-inner
  ul.menu
  > li.menu-parent
  li.menu-parent
  span.menu-toggler {
  display: inline;
  position: relative;
  top: 2px;
  padding-right: 100px;
}

/* || - - Mobile Menu Close */
.close-offcanvas {
  top: 55px;
}

/*
|| - - BREADCRUMB
*/
.smf #sp-breadcrumb {
  background-color: var(--clr__blue_dark);
}

.smf #sp-breadcrumb .breadcrumb {
  margin: 0px;
  padding-left: 0px;
  background-color: unset;
}

.smf #sp-breadcrumb a {
  color: var(--clr__white-accent);
}

.smf #sp-breadcrumb a:hover {
  color: var(--clr__magenta-accent);
}

.smf #sp-breadcrumb li.active span {
  color: var(--clr__teal);
}

.smf #sp-breadcrumb li span {
  text-transform: lowercase !important;
}

#breadcrumb .breadcrumb-item:first-child + .breadcrumb-item::before {
  content: "|" !important;
}

#so-logo-breadcrumb {
  width: 35px;
}

/*
|| - PAGES
|| - - HOMEPAGE
*/
/*
|| - - CONTACT DIRECTORIES
*/
.faculty .sppb-addon-header {
  border-bottom: 1px solid var(--clr__grey);
  padding-top: 75px;
}

.faculty #page-title .sppb-addon-header {
  border-bottom: none !important;
  padding-top: unset;
}

.smf .faculty .personlist {
  justify-content: space-around !important;
}

@media screen and (max-width: 767px) {
  .smf .faculty .personlist {
    flex-direction: column;
  }
}

.smf .faculty .personlist .person {
  flex: 0 1 30% !important;
  margin-right: 40px !important;
  margin-bottom: 40px !important;
  position: relative;
}

@media screen and (max-width: 991px) {
  .smf .faculty .personlist .person {
    flex: 1 1 50% !important;
  }
}

.smf .faculty .personlist img {
  max-width: 300px !important;
  height: auto !important;
}

.smf .faculty .person .person-card-caption {
  position: absolute;
  bottom: 0;
  width: 100%;
  background-image: var(--img-caption__bg-start);
  color: var(--clr__white-accent);
  background-size: 200%;
  background-position: 40%;
  transition: background-position var(--time__transition-duration) ease-in-out;
  padding-left: 1em;
  padding-bottom: 0.5em;
}

.smf .faculty .person:hover .person-card-caption {
  background-position: 10%;
}

.smf .faculty .person .person-card-caption span {
  display: block;
  width: 100%;
  text-align: left;
}

.smf .faculty .person-card-container .person-name {
  font-size: 1.5em;
}

/*
|| - - - CONTACT PAGES
*/
.smf.contact #sp-main-body {
  padding-top: 0px;
}

/* component overrides */
.contact .component-template .header-item,
.contact.component-template .header-item {
  max-width: 50%;
  margin-right: 40px;
  margin-bottom: 40px;
}

.contact .component-template .header-item img,
.contact.component-template .header-item img {
  max-width: 225px;
  height: auto;
}

@media screen and (max-width: 500px) {
  .contact .component-template .page-header,
  .contact.component-template .page-header {
    flex-direction: column;
  }

  .contact .component-template .header-item,
  .contact.component-template .header-item {
    max-width: 100%;
  }
}

/*
|| - UTILITY CLASSES
*/
.float-left {
  float: left !important;
}

.bottom-right-curve,
.bottom-right-curve img {
  border-radius: 0 0 25px 0;
}

.top-right-curve,
.top-right-curve img {
  border-radius: 0 25px 0 0;
}

.bottom-left-curve,
.bottom-left-curve img {
  border-radius: 0 0 0 25px;
}

div > .grow {
  transform: scale(100%);
  transition: transform var(--time__transition-duration) ease-in;
}

div:hover > .grow {
  transform: scale(110%);
}

.overflow-hidden {
  overflow: hidden;
}

.bg_white-accent {
  background-color: var(--clr-bg__white-accent);
}

.bg_green-accent {
  background-color: var(--clr-bg__green-accent);
}

/* Text color */
.clr__blue {
  color: var(--clr__blue-main) !important;
}

.clr__teal {
  color: var(--clr__teal) !important;
}

.clr__teal-900 {
  color: var(--clr__teal-900) !important;
}

.clr__blue_secondary {
  color: var(--clr__teal) !important;
  /* or you can use clr__teal here */
}

.clr__blue_dark {
  color: var(--clr__blue_dark) !important;
}

.clr__blue_green {
  color: var(--clr__blue_green) !important;
}

.clr__green-accent {
  color: var(--clr__green-accent) !important;
}

.clr__orange {
  color: var(--clr__orange) !important;
}

.clr__magenta-accent {
  color: var(--clr__orange) !important;
  /* or you can use clr__orange here */
}

.clr__magenta-100 {
  color: var(--clr__magenta-100) !important;
}

.clr__offwhite_main {
  color: var(--clr__offwhite_main) !important;
}

.clr__white-accent {
  color: var(--clr__white-accent) !important;
}

.clr__white-100 {
  color: var(--clr__white-100) !important;
}

.clr__yellow {
  color: var(--clr__yellow) !important;
}

/* Background color */
.clr-bg__blue {
  background: var(--clr__blue-main) !important;
}

.clr-bg__teal {
  background: var(--clr__teal) !important;
}

.clr-bg__teal-900 {
  background: var(--clr__teal-900) !important;
}

.clr-bg__blue_secondary {
  background: var(--clr__teal) !important;
  /* or you can use clr__teal here */
}

.clr-bg__blue_dark {
  background: var(--clr__blue_dark) !important;
}

.clr-bg__blue_green {
  background: var(--clr__blue_green) !important;
}

.clr-bg__green-accent {
  background: var(--clr__green-accent) !important;
}

.clr-bg__orange {
  background: var(--clr__orange) !important;
}

.clr-bg__magenta-accent {
  background: var(--clr__orange) !important;
}

.clr-bg__magenta-100 {
  background: var(--clr__magenta-100) !important;
}

.clr-bg__offwhite_main {
  background: var(--clr__offwhite_main) !important;
}

.clr-bg__white-accent {
  background: var(--clr__white-accent) !important;
}

.clr-bg__white-100 {
  background: var(--clr__white-100) !important;
}

.clr-bg__yellow {
  background: var(--clr__yellow) !important;
}

#sp-page-builder.bg-white {
  background-color: transparent !important;
}

.bg-white #sp-main-body {
  background-color: var(--clr__white-accent) !important;
}

@media screen and (min-width: 992px) {
  .bg-white #sp-main-body {
    background-image: url("/images/smf/backgrounds/trans_bg_with_palm_1920.webp");
    background-repeat: no-repeat;
    background-size: cover;
    background-attachment: fixed;
  }
}
