@import url('//fonts.googleapis.com/css2?family=Josefin+Sans:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;1,100;1,200;1,300;1,400;1,500;1,600;1,700&family=Josefin+Slab:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;1,100;1,200;1,300;1,400;1,500;1,600;1,700&display=swap');
/************ TEMPLATE  ************

************/

.site-1 {
    --primary-color: #6B94B3;
    --secondary-color: #2D4C64;
    --tertiary-color: #203646;

    --primary-rgb: 107,148,179;
    --secondary-rgb: 45,76,100;
    --tertiary-rgb: 32,54,70;

    --default-white: #ffffff;
    --default-black: #000000;
    --default-grey: #f1f2f2;

    --title-font-family: 'Josefin Slab', serif;
    --body-font-family: 'Josefin Sans', sans-serif;

    --heading-color: var(--primary-color);
    --heading-font-family: var(--title-font-family);

    --title-border-bottom: 1px solid var(--secondary-color);

    --home-title-font: var(--title-font-family);

    --transparent: rgba(255,255,255,0);

    --default-box-shadow: 0px 0px 10px rgba(0,0,0,.3);

    --swiper-box-shadow: var(--default-box-shadow);

    --ql-title-color: var(--default-white);

    --grid-vertical-gap: 2vw;

    --grid-tile-height: 14vw;

    --hero-title-color: var(--secondary-color);
}

.site-1 .ql-fa-toplinks {
    --ql-title-color: var(--primary-color);
}

.readon, .button, .btn, p.readmore .btn, .sprocket-lists-portrait-container > li .sprocket-lists-portrait-item > a span, .listentobutton.moduletable a {
    background: var(--primary-color);
    font-family: var(--body-font-family);
    padding: 1rem 2.3rem;
    border-radius: 1.7rem;
    font-size: 1.25rem;
} 

/*************** ALL SITE *****************/
.item-image {display: none;}

/*************** HOMELAYOUT ***************/ 
/*************** OFFCANVAS ****************/
.g-offcanvas-toggle {color: var(--default-white);} 
.g-offcanvas-toggle .fa-fw {text-shadow: none;}

@media only screen and (max-width: 50.99rem) {
    .site-1 #g-offcanvas .g-social-items {
        display: flex;
        flex-direction: row;
        gap: 2rem;
        align-items: center;
        justify-content: center;
    }
    .site-1 #g-offcanvas .g-social-items a {
        color: var(--secondary-color);
    }
    .site-1 #g-offcanvas .g-social-items a:hover {
        color: var(--tertiary-color);
    }
}

/*************** TOP **********************/ 
#g-top {color: var(--primary-color);}


/*************** NAVIGATION ***************/
@media only screen and (min-width: 50.99rem) {
    .site-1 #g-navigation .g-logo img {
        width: 60%;
    }
    .site-1 #g-navigation > .g-container > .g-grid:nth-child(2) {
        padding: 2vw 1vw;
    }
    .site-1 #g-navigation > .g-container > .g-grid:nth-child(3) {
        box-shadow: var(--default-box-shadow);
    }
    .site-1 #g-navigation > .g-container {
        padding-bottom: 2vw!important;
        background: url('/images/template/mary1.png') 5% 0% no-repeat;
        background-size: 12.5%;
    }
}

@media only screen and (min-width: 50.99rem) {
    .g-main-nav .g-toplevel>li>.g-menu-item-container>.g-menu-item-content {
        font-size: 1.25vw;
        line-height: 1.25vw;
        font-family: var(--body-font-family);
        font-weight: 400;
    }
    .g-main-nav .g-sublevel>li>.g-menu-item-container>.g-menu-item-content>.g-menu-item-title {
        font-size: 1.25vw;
        line-height: 1.25vw;
        font-family: var(--body-font-family);
        font-weight: 400;
    }
    .g-main-nav .g-toplevel > li {
        transition: .3s all ease-in-out;
    }
    .g-main-nav .g-toplevel > li:not(.g-main-nav .g-toplevel > li:last-child):hover {
        background: rgba(var(--secondary-rgb),.3);
    }

    .site-1 #g-navigation .g-social-items {
        display: flex;
        flex-direction: row;
        gap: 2vw;
        align-items: center;
    }
    .site-1 #g-navigation .g-social-items a {
        color: var(--secondary-color);
        font-size: 1.25vw;
        line-height: 1.25vw;
    }
    .site-1 #g-navigation .g-social-items a:hover {
        color: var(--tertiary-color);
    }
}
@media only screen and (max-width: 50.99rem) {
    #g-navigation .g-logo {
        max-width: 65%;
        margin: 2rem auto;
    }
}
/*************** SLIDESHOW ****************/ 
@media only screen and (min-width: 50.99rem) {
    .mass-times-block {
        background: url('/images/stories/template/masstimes.png') 150% 100% no-repeat;
        background-size: 100%;
    }
    .site-1-home #g-slideshow {
        position: relative;
        box-shadow: var(--default-box-shadow);
    }
}
@media only screen and (max-width: 50.99rem) {
    .mass-times-block {
        background: url('/images/stories/template/masstimes.png') 150% 100% no-repeat;
        background-size: 100%;
    }
    .site-1-home #g-slideshow {
        position: relative;
        box-shadow: var(--default-box-shadow);
    }
}

/*************** HEADER *******************/
#hero-title-text {
    font-weight: 400;
}

/*************** ABOVE ********************/
/*************** SHOWCASE *****************/
@media only screen and (min-width: 50.99rem) {
    .site-1-home #g-showcase {
        background: linear-gradient(to top, var(--secondary-color), rgba(var(--secondary-rgb), .6)), var(--primary-color);
    }
    .site-1-home #g-showcase > .g-container {
        padding: 4vw 10%!important;
    }
    .site-1-home #g-showcase .g-title {
        font-size: 7vw;
        font-family: var(--title-font-family);
        font-weight: 400;
        margin-bottom: 2vw;
        text-transform: none;
        font-variant-caps: normal;
        color: var(--default-white);
    }
    .circle-links.ql-height16vw .g-blockcontent-subcontent-block-content {
        box-shadow: var(--default-box-shadow);
    }
}

@media only screen and (max-width: 50.99rem) {
    .site-1-home #g-showcase .g-container {
        padding: 2rem 0!important;
    }
    .site-1-home #g-showcase .g-title {
        font-size: 10vw;
        font-family: var(--title-font-family);
        font-weight: 400;
        margin-bottom: 2vw;
        text-transform: none;
        font-variant-caps: normal;
        color: var(--default-white);
    }
}

/*************** UTILITY ******************/
.site-1-home #g-utility .button {
    background: var(--secondary-color);
}
.site-1-home #g-utility .button:hover {
    background: #777;
}

@media only screen and (min-width: 50.99rem) {
    .site-1-home #g-utility {
        background: url('/images/stories/template/parallax-news-blur.jpg') 50% 50% no-repeat;
        background-size: cover;
        background-attachment: fixed;
    }
    .site-1-home #g-utility > .g-container {
        padding: 5vw 5%!important;
    }
    .site-1-home #g-utility > .g-container > .g-grid:nth-child(1) > .g-block:nth-child(2) {
        display: none!important;
    }
    .site-1-home #g-utility > .g-container > .g-grid:nth-child(1) > .g-block:last-child {
        display: flex;
        justify-content: center;
        align-items: center;
    }
}

@media only screen and (max-width: 50.99rem) {
    .site-1-home #g-utility {
        background: url('/images/stories/template/parallax-news-blur.jpg') 50% 50% no-repeat;
        background-size: cover;
    }
    .site-1-home #g-utility > .g-container {
        padding: 2rem 1rem!important;
    }
    .site-1-home #g-utility > .g-container > .g-grid:last-child {
        display: none!important;
    }
}

@media only screen and (min-width: 50.99rem) {
    .ph-rec-row .g-title {
        color: var(--default-black);
        font-size: 5vw;
        text-shadow: 0px 0px 5px rgba(0,0,0,.4);
        text-transform: none;
        font-variant-caps: normal;
        font-weight: 700;
    }

    .ph-rec-row.ph-background-effect .g-array-item:hover {
        background: var(--default-white);
    }
    .ph-rec-row.ph-background-effect .g-array-item .g-array-item-image {
        overflow: hidden;
    }
    .ph-rec-row.ph-background-effect .g-array-item .g-array-item-image img {
        transition: .3s all ease-in-out;
        height: unset;
        aspect-ratio: 16 / 9;
    }
    .ph-rec-row.ph-background-effect .g-array-item:hover .g-array-item-image img {
        transform: scale(1.05);
    }
}

@media only screen and (max-width: 50.99rem) {
    .ph-rec-row .g-title {
        color: var(--default-white);
        font-size: 10vw;
        text-shadow: var(--defalt-box-shadow);
        text-transform: none;
        font-variant-caps: normal;
        font-weight: 400;
        text-align: center;
    }
}

/*************** FEATURE ******************/
/*************** MAIN *********************/
.site-1-home :is(#g-mainbar, #g-sidebar, #g-aside) {
    background: transparent;
}
@media only screen and (min-width: 50.99rem) {
    .site-1-home #g-container-main {
        background: linear-gradient(to top, var(--secondary-color), rgba(var(--secondary-rgb), .6)), var(--primary-color);
        padding: 4vw 5%;
    }

    .site-1-home #g-container-main .g-title {
        color: var(--default-white);
        border-bottom: 1px solid var(--primary-color);
        font-size: 3vw;
        font-weight: 400;
    }
}

@media only screen and (max-width: 50.99rem) {
    .site-1-home #g-container-main .g-title {
        color: var(--default-white);
        border-bottom: 1px solid var(--primary-color);
    }
}

@media only screen and (max-width: 50.99rem) {
    .site-1-home #g-mainbar > .g-grid > .g-block > .g-content {
        margin: 0;
        padding: 0;
    }
}

@media only screen and (min-width: 50.99rem) {
    .site-1-sub #g-mainbar {
        min-height: 30vh;
    }
}

@media only screen and (max-width: 50.99rem) {
    :is(.site-1-sub, .site-2-sub) #g-mainbar > .g-grid > .g-block > .g-content {
        margin: 0;
        padding: 0;
    }
}

/*************** EXPANDED *****************/ 
/*************** EXTENSION ****************/
/*************** BOTTOM *******************/
@media only screen and (min-width: 50.99rem) {
    .site-1 #g-bottom {
        padding: 2vw 0!important;
        position: relative;
        z-index: 100;
    }
    .site-1 #g-bottom .admod td {
        padding: 0;
    }
}

/*************** FOOTER *******************/
#g-footer .g-content-array {margin: 0;}
#g-footer a {color: var(--default-white); transition: .3s all ease-in-out;}
#g-footer a:hover {opacity: 0.5;} 

@media only screen and (min-width: 50.99rem) {
    #g-container-footer {
        background: url('/images/template/mary1.png') 2.5% 0% no-repeat, var(--primary-color);
        background-size: 12.5%;
    }
}

@media only screen and (max-width: 50.99rem) {
    #g-bottom {
        background: var(--primary-color);
    }
    #g-container-footer {
        background: var(--primary-color);
    }
}

.site-1 #g-footer .ql-inner-box {
    --ql-background-color: rgba(0,0,0,.2);
    --ql-background-hover: rgba(0,0,0,.4);
}

@media only screen and (min-width: 50.99rem) {
    #g-container-footer {
        margin-top: calc(-6vw - 50px)!important;
        padding-top: calc(6vw + 50px)!important;
    }

    #g-footer {
        padding: 0 2vw 2vw 2vw!important;
    }

    #g-footer :is(h1,h2,h3,h4,h5,h6) {
        font-size: 3vw;
    }

    #g-footer :is(p, p > a, span > a) {
        color: var(--default-black);
        font-size: 1.25vw;
    }

    .site-1 #g-footer .ql-inner-box .g-blockcontent-subcontent-block {
        box-shadow: var(--default-box-shadow);
    }
    .site-1 #g-footer .ql-inner-box .g-blockcontent-subcontent-title > .g-blockcontent-subcontent-title-text {
        border: none;
    }
    .site-1 #g-footer .ql-inner-box .g-blockcontent-buttons {
        opacity: 0;
    }
    .site-1 #g-footer .ql-inner-box .g-blockcontent-subcontent {
        gap: 2vw;
        width: 80%;
    }
    .site-1 #g-footer .ql-inner-box .g-blockcontent {
        display: flex;
        justify-content: center;
        align-items: center;
    }
}

@media only screen and (max-width: 50.99rem) {
    #g-footer {
        padding: 1rem!important;
    }
    .site-1 #g-footer .ql-inner-box .g-blockcontent-buttons {
        opacity: 0;
    }
}

/*************** COPYRIGHT ****************/ 
@media only screen and (max-width: 50.99rem) {
    .web-policy {
        justify-content: flex-end;
        padding-right: 10px;
    }
    .site-1 .adminfootericon {
        bottom: 40px
    }

    .site-2 .adminfootericon {
        bottom: 40px
    }
}

/*************** MODULES ******************/
.moduletable .nav.menu, .moduletable .unstyled {background: var(--primary-color);} 
.moduletable .nav.menu li.current.active a, .moduletable .nav.menu li a:hover {    
    color: var(--default-white); 
    background: var(--secondary-color);
} 
/*************** SECTIONS *****************/
/*************** MOBILE *******************/ 
/*************** ADS **********************/

@media only screen and (min-width: 50.99rem) {
    #site-grid #g-container-main {
        padding-bottom: 3vw;
    }
}

@media only screen and (max-width: 50.99rem) {
    .grid.ph-sidebyside-mobile .g-array-item-read-more {
        opacity: 0;
    }
    .grid.ph-sidebyside-mobile .g-array-item-title {
        padding: 1rem;
    }
}

@media only screen and (min-width: 50.99rem) {
    .search-page button.btn {
        background: var(--primary-color)!important;
    }
    .search-page button.btn:hover {
        background: var(--secondary-color)!important;
    }
}

@media only screen and (max-width: 50.99rem) {
    .search-page button.btn {
        background: var(--primary-color)!important;
    }
    .search-page button.btn:hover {
        background: var(--secondary-color)!important;
    }
}

@media only screen and (max-width: 50.99rem) {
    .ph-sidebyside-mobile .g-array-item-read-more {
        opacity: 0;
    }
    .ph-sidebyside-mobile .g-array-item-title {
        padding: 1rem;
    }
}

@media only screen and (min-width: 50.99rem) {
    .bilingual {
        display: flex;
        flex-direction: row;
        align-items: flex-start;
        gap: 2vw;
    }
    .bilingual .englishtext {
        flex: 1;
    }
    .bilingual .spanishtext {
        flex: 1;
        font-style: italic;
    }
}

@media only screen and (max-width: 50.99rem) {
    .bilingual {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
    }
    .bilingual .englishtext {
        flex: 1;
    }
    .bilingual .spanishtext {
        flex: 1;
        font-style: italic;
    }
}