:root {
    --main-font: "proxima-nova", Helvetica, Arial, sans-serif;
    --heading-font: "proxima-nova", Helvetica, Arial, sans-serif;
    --base-font-size: 1.25rem;
    --container-width: 80.625rem;
}

/* Font Overrides */
body,
.display-text,
.display-text--x-large,
.display-text--large,
.display-text--medium,
.display-text--small,
.button,
button,
.label,
blockquote,
#mega-menu .top-bar-section .nav-links li,
#mega-menu .top-bar-section .nav-links>li>button,
body>header #nav .site-header .site-name,
body>header .logo-tools .tools #search span,
body>header .logo-tools .tools #menu span,
body>header .logo-tools .tools #mmenu span,
body>header .site-header .tools #search span,
body>header .site-header .tools #menu span,
body>header .site-header .tools #mmenu span,
.global-header .global-nav-wrapper .global-nav .top-bar-section>ul>li.has-dropdown>a,
.global-header .global-nav-wrapper .global-nav .top-bar-section>ul>li .dropdown a,
.side-nav li span,
section nav ul.sub-nav li,
.blockquote-container cite,
.accordion .accordion-navigation>a,
.accordion.accordion-refresh .accordion-navigation>a,
.accordion dd>a,
.accordion.accordion-refresh .accordion-navigation>a,
.tabs dd>a,
.tabs .tab-title>a,
.tabs .tab-title a,
footer h2 {
    font-family: var(--main-font);
}

/* Typography */
main,
.panel {

    h1,
    h2,
    h3,
    h4,
    h5,
    h6,
    .h1,
    .h2,
    .h3,
    .h4,
    .h5,
    .h6,
    .display-text--x-large,
    .display-text--large,
    .display-text--medium,
    .display-text--small,
    .display-text,
    p {
        margin: 0 0 1.25rem;
    }

    h1,
    h2,
    h3,
    h4,
    h5,
    h6,
    .h1,
    .h2,
    .h3,
    .h4,
    .h5,
    .h6,
    .display-text--x-large,
    .display-text--large,
    .display-text--medium,
    .display-text--small,
    .display-text {
        font-family: var(--heading-font);
    }

    h1,
    .h1 {
        font-size: 4rem;
        line-height: 1.125;
        font-weight: 800;
    }

    h2,
    .h2,
    .display-text--x-large {
        font-size: 3rem;
        line-height: 1.1667;
        font-weight: 800;

        *:not(h1):not(.pretitle)+& {
            margin-top: 3rem;
        }
    }

    h3,
    .h3,
    .display-text--large {
        font-size: 2rem;
        line-height: 1.25;
        font-weight: 700;

        *:not(h2):not(.pretitle)+& {
            margin-top: 2.5rem;
        }
    }

    h4,
    .h4,
    .display-text--medium {
        font-size: 1.75rem;
        line-height: 1.14286;
        font-weight: 700;

        *:not(h3):not(.pretitle)+& {
            margin-top: 2rem;
        }
    }

    h5,
    .h5,
    .display-text--small {
        font-size: 1.5rem;
        line-height: 1.333;
        font-weight: 700;
    }

    h6,
    .h6,
    .display-text {
        font-size: 1.25rem;
        line-height: 1.4;
        font-weight: 700;
    }

    p,
    li,
    .button,
    dt,
    dd {
        font-size: var(--base-font-size);
        line-height: 1.5;
    }

    .body-lg {
        font-size: 1.375rem;
    }

    .body-sm {
        font-size: 1rem;
    }

    .body-xs {
        font-size: 0.875rem;
    }

    .lead,
    p.lead {
        font-size: 1.5rem;
    }

    small,
    .p-small {
        font-size: 0.875rem;
    }

    .pretitle {
        margin-bottom: 0.625rem;
        font-size: 1.25rem;
        font-style: normal;
        font-weight: 400;
        line-height: 1.5;
        letter-spacing: 0.173em;
        text-transform: uppercase;
    }

    .fw-light {
        font-weight: 300 !important;
    }

    .fw-normal {
        font-weight: normal !important;
    }

    .fw-medium {
        font-weight: 500 !important;
    }

    .fw-semi-bold {
        font-weight: 600 !important;
    }

    .fw-bold {
        font-weight: 700 !important;
    }

    .fw-extra-bold {
        font-weight: 800 !important;
    }

    .fw-black {
        font-weight: 900 !important;
    }
}

/* General Structure */
.row,
.contain-to-grid .top-bar,
.content-block .row,
#fiu-sub-nav nav,
.multimedia-bg .wrapper {
    max-width: var(--container-width);
}

.anchored-nav.row {
    margin-bottom: 1rem;
}

dl dd+dd {
    margin-top: -0.75rem;
}

dl dd+dt {
    margin-top: 1rem;
}

.button {
    font-size: 0.9rem;
}

.cta-link-primary>a,
.cta-link-primary>button,
a.cta-link-primary,
button.cta-link-primary,
a.primary {
    margin-right: 1.3em;
}

.accessible-max-width {
    max-width: 833.33px;
}

body>header #nav .site-header .button {
    min-width: 0;
}

@media (min-width: 1025px) {

    body>header .logo-tools .tools #search,
    body>header .logo-tools .tools #menu,
    body>header .logo-tools .tools #mmenu,
    body>header .site-header .tools #search,
    body>header .site-header .tools #menu,
    body>header .site-header .tools #mmenu {
        padding-right: 0 !important;
    }
}

.related-content .button {
    width: 100%;
}

.panel a:not(cta-link-primary):not(button) {
    text-decoration: underline;
}

.rounded,
.panel,
.padded-block {
    border-radius: 8px;
}

.note {
    font-size: 0.875rem;
}

.hide {
    display: none !important;
}

.full-media-content.centered .content {
    margin: 0 auto;
}


/* Unstyled List */
.list-unstyled {
    list-style: none;
    margin-left: 0;
}

.list-unstyled li+li {
    margin-top: 0.375rem;
}

/* Ordered List */
ol li+li {
    margin-top: 0.375rem;
}

/* Checklist */
ul.checklist {
    margin: 0 0 1.25rem 1rem;
}

ul.checklist>li {
    position: relative;
    margin: 0;
    padding: 0 0 0 0.75rem;
    list-style: none;
}

ul.checklist>li::before {
    content: "\f00c";
    position: absolute;
    left: -1em;
    font-family: "Font Awesome 6 Free";
    display: inline !important;
    text-decoration: none !important;
    font-weight: 600 !important;
    position: absolute;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    color: #215f2d;
}

ul.checklist>li+li {
    margin-top: 0.5rem;
}

/* Responsive Video */
.flex-video.vertical {
    padding-bottom: 168%;
}

.flex-video.vertical.vimeo {
    padding-bottom: 177.8%;
}

@media (max-width: 1024px) {
    .flex-video {
        margin-top: 1rem;
        margin-bottom: 1rem;
    }
}

/* Header */
body>header #nav .nav-links>li>a,
body>header #nav .nav-links>li>button {
    font-size: 1rem;
}

body>header .top-bar-section .nav-links li.has-dropdown a:not(.button) span {
    font-size: 0.9375rem !important;
}

/* Subnav */
@media (min-width: 1025px) {
    .fiu-sub-nav-wrapper {
        height: auto;
    }
}

@media (min-width: 641px) {

    .row.flex-align-items-end,
    .flex-align-items-end>.row {
        display: flex;
        align-items: flex-end;
    }

    .content-block>.row>[class="columns"]:first-child {
        margin-bottom: 2rem;
    }

    .content-block>.row.overlapping-media-wrapper>[class="columns"]:first-child {
        margin-bottom: 0;
    }
}

@media (min-width: 1025px) {
    .content-block {
        padding-top: 4.5rem;
        padding-bottom: 4.5rem;
    }

    .content-block.multimedia-bg {
        padding-top: 0;
        padding-bottom: 0;
    }

    .content-block.content-block--max-width>.row>.columns:only-child {
        max-width: 66.66667%;
    }
}

/* Banner */
#banner.banner-flex,
#banner-video.banner-flex {
    .content-flex {
        justify-content: flex-start;
    }

    .content-flex .content,
    .content-flex .content {
        padding-left: 0;
        padding-right: 0;
        width: auto;
        max-width: 66.6667%;
    }

    @media (max-width: 640px) {

        .content-flex .content,
        .content-flex .content {
            width: auto;
            max-width: 100%;
        }
    }
}

/* Hide parent section when only child has .hide. Typically for data-only modules */
#page-content>article:has(.hide:only-child) {
    display: none;
}

@media (max-width: 640px) {
    .content-block {
        &>.row .columns+.columns {
            margin-top: 0.9375rem;
        }
    }

    /* Reverse columns on mobile */
    .module-mobile-reverse-columns {
        &>.row {
            display: flex;
            flex-direction: column-reverse;
        }

        &>.row .columns:first-child {
            margin-top: 0.9375rem;
        }

        &>.row .columns+.columns {
            margin-top: 0;
        }
    }
}

/* For two-column modules where the right column must be flush against the viewport */
@media (min-width: 1250px) {
    .module-right-column-flush {
        position: relative;

        &>.row {
            position: relative;
        }

        .row .columns+.medium-8 {
            position: absolute;
            padding-right: 0;
            height: 100%;
            right: calc((100vw - 62.5rem) / -2);
            width: calc((62.5rem * 0.6667) + ((100vw - 62.5rem) / 2));
        }

        .row .columns+.medium-6 {
            position: absolute;
            padding-right: 0;
            height: 100%;
            right: calc((100vw - 62.5rem) / -2);
            width: calc((62.5rem * 0.5) + ((100vw - 62.5rem) / 2));
        }

        .row .columns+.medium-4 {
            position: absolute;
            padding-right: 0;
            height: 100%;
            right: calc((100vw - 62.5rem) / -2);
            width: calc((62.5rem * 0.3333) + ((100vw - 62.5rem) / 2));
        }

        .columns+.columns {
            display: flex;
        }

        .columns+.columns>img,
        .columns+.columns>p:has(img:only-child) img {
            object-fit: cover;
            width: 100%;
            height: 100%;
        }

        &.content-min-height {
            &>.row>.columns:first-child {
                display: flex;
                flex-direction: column;
                justify-content: center;
                min-height: 500px;
            }
        }
    }
}

/* Full-width + media */
.row.full-media-content {
    max-width: 100%;
}

/* Full width content block */
.content-block--full-width {
    .row {
        max-width: 100%;
    }

    .columns:only-child {
        padding-left: 0;
        padding-right: 0;
    }
}

/* Page Intro Spacing Issues */
#page-intro>.content-block.white:first-child>.columns>h1:last-child {
    margin-bottom: 0 !important;
}

#page-intro+article>.content-block.white:first-child,
#page-intro+article>.content-block.fiu-background-white:first-child {
    padding-top: 0;
}

#page-intro[aria-hidden="true"]+article>.white:first-child,
#page-intro[aria-hidden="true"]+article>.fiu-background-white:first-child {
    padding-top: 2.5rem;
}

@media (min-width: 1025px) {
    #page-intro>.content-block.white:first-child {
        padding-top: 2rem;
    }

    #page-intro+article>.content-block.white:first-child,
    #page-intro+article>.content-block.fiu-background-white:first-child,
    [data-magellan-destination="1"]+article>.content-block.white:first-child,
    [data-magellan-destination="1"]+article>.content-block.fiu-background-white:first-child,
    #page-intro+article #searchable-interface-wrapper {
        padding-top: 0;
        margin-top: -3.5rem;
    }

    #page-intro[aria-hidden="true"]+article>.fiu-background-white:first-child,
    #page-intro[aria-hidden="true"]+article>.white:first-child {
        margin-top: 0;
        padding-top: 2rem;
    }

    .multimedia-bg.dark .panel {
        padding: 4.5rem 0 !important;
        margin: 0 auto;
        max-width: 66.66667%;
        width: auto;
    }

    .content-block.padding-sm {
        padding-top: 2.5rem;
        padding-bottom: 2.5rem;
    }

    .content-block.padding-top-sm {
        padding-top: 2.5rem;
    }

    .content-block.padding-bottom-sm {
        padding-bottom: 2.5rem;
    }

    .content-block.multimedia-bg {
        padding-top: 0;
        padding-bottom: 0;
    }
}

@media (max-width: 640px) {

    .content-block .row .medium-8+.medium-4,
    .content-block .row .medium-4+.medium-8 {
        margin-top: 1rem;
    }
}

/* Multimedia Backgrounds */
.multimedia-bg .wrapper {
    margin-left: auto;
    margin-right: auto;
    max-width: 1600px;
}

/* Simple table */
table.simple-table,
table.simple-table th, 
table.simple-table td, 
table.simple-table thead, 
table.simple-table tr.even, 
table.simple-table tr.alt,
table.simple-table tr:nth-of-type(even) {
    background: transparent;
    border:none;
    font-size:1rem;
}
/* Updated box shadow on panels */
.panel-box-shadow .panel {
    border:none;
    border-radius: 5px;
    box-shadow: 0 10px 37px 0 rgba(0, 0, 0, 0.25);
}
.panel-padding .panel {
    padding-top: 4rem;
    padding-bottom: 4rem;
}
/* Custom flex-cards */
.custom-logo-list {
  display: flex;
  flex-wrap: wrap !important;
  justify-content: center;
  align-items: center;
  gap: 1rem;
  margin: 0;
  list-style: none;
  padding-top: 1rem;
}
.custom-logo-list > * {
  flex: 0 0 calc(50% - 0.5rem);
  box-sizing: border-box;
}

.custom-logo-list li  {
  text-align:center;
  padding: 1rem;
}
/* Inline stats-list */
.inline-stats-list li {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
}


/* Custom Icon list */
 ul.icon-list {
	 list-style: none;
	 margin-left: 1.6rem;
}
 ul.icon-list li {
	 margin: 1.5rem 0 1.8rem .5rem;
	 position:relative;
	 padding-left: .25rem;
}
 ul.icon-list li:before {
	 position:absolute;
	 font-family:"Font Awesome 6 Free";
	 font-weight: 600 !important;
	 font-size: 1.5rem;
	 display:block;
	 left: -2rem;
	 top: 0rem;
}
li.green-check:before {
	 content: "" !important;
	 color:green !important;
}
@media (min-width: 1025px) {
    .align-panel .panel {
        max-width: 52.5rem !important;
        margin-left: 10.5rem !important;
        margin-top: 19.85rem !important;
    }
    .align-bottom > .row {
        display: flex;
        align-items: flex-end;
    }
    .accordion-two-column  > .row {
        display: flex;
        justify-content: center;
    }
    
}
