@import url('//fonts.googleapis.com/css2?family=Lato:ital,wght@0,100;0,300;0,400;0,700;0,900;1,100;1,300;1,400;1,700;1,900&display=swap');
/************ TEMPLATE  ************
Mockup #3_v2 Green Approved

REVISIONS (OUTSIDE OF MOCKUP)
- Still deciding on the colors and if they want it to change with the liturgical seasons.

FONTS / ALTERNATIVES / WEIGHTS
Display/Logo: Gautreaux (Adobe)
Body: Lato
Colors: Dark Gray or White rgb(119, 119, 119)

COLORS (GRADIENTS IF ANY) INCLUDE RGB
Primary: Green 295b34 rgb(41,91,52)
Secondary: White
Hover Effect: Dark gray with white text or light gray when hovering icons for example

IMAGES (OPACITY, BLUR RADIUS IN PX, ROTATOR RATIO)
- Footer image color at 87% opacity and add 2px Radius Blur

VECTOR GRAPHICS (IF ANY) [SPECIAL ICONS?]
- For the header and footer logo I've included an SVG for the text part of the logo if needed (logo-text-only-white)

ADDITIONAL NOTES (FX, REQUESTS, HELPFUL TEXT)
- Rotator Mass Times and Buttons at 75% Opacity

(Reminder for Adam) Make image sizes  500 - 600kb or smaller
************/

.site-1 {
    --primary-color: #295b34;
    --secondary-color: #ffffff;
    --tertiary-color: #777777;

    --primary-rgb: 41,91,52;
    --secondary-rgb: 255,255,255;
    --tertiary-rgb: 119,119,119;

    --default-white: #ffffff;
    --default-black: #000000;

    --title-font-family: 'Lato', sans-serif;
    --body-font-family: 'Lato', 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,.5);

    --swiper-box-shadow: var(--default-box-shadow);

    --ql-title-color: var(--default-white);

    --mt-header-font-weight: 700;
    --mt-header-desktop: 2.25vw;
}

h6 {color: var(--tertiary-color);}

.site-1 .ql-fa-toplinks {
    --ql-title-color: var(--default-white);
    --ql-title-hover: var(--default-black);
    --ql-icon-hover: var(--default-black);

    --ql-background-color: none;
    --ql-background-hover: rgba(255,255,255,.5);
}

.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);
} 

/*************** 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 **********************/ 
/*************** NAVIGATION ***************/
@media only screen and (min-width: 50.99rem) {
    .site-1 #g-navigation > .g-container > .g-grid:nth-child(1) {
        padding: 1vw!important;
    }
    .site-1 #g-navigation > .g-container > .g-grid:nth-child(2) {
        box-shadow: var(--default-box-shadow);
        position: relative;
    }
    .site-1 #g-navigation .g-main-nav {
        padding: 1.5vw 0;
    }
    .site-1 #g-navigation .g-toplevel {
        padding-left: 15%;
    }
    .site-1 #g-navigation .g-main-nav .g-toplevel>li.active>.g-menu-item-container {
        border-bottom: 2px solid var(--primary-color);
    }
    .site-1 #g-navigation .nav-logo-icon {
        padding: .75vw;
        background: var(--default-white);
        box-shadow: var(--default-box-shadow);
        border-radius: 2px;
        overflow: hidden;
        position: relative;
        z-index: 100;
        margin-bottom: -5vw;
    }
    .site-1 #g-navigation .nav-logo-text {
        padding-left: 2vw;
    }
    .site-1-home #g-navigation .g-toplevel > li:has(.g-social-items) {
        display: none!important;
    }

    .ql-fa-toplinks .g-blockcontent-subcontent-block:not(.ql-fa-toplinks .g-blockcontent-subcontent-block:last-child) {
        border: none;
    }
    .ql-fa-toplinks .g-blockcontent-subcontent-title-icon {
        font-size: 2.25vw;
    }
    .ql-fa-toplinks .g-blockcontent-subcontent-title-text {
        font-size: 1.25vw;
    }
    .ql-fa-toplinks .g-blockcontent-subcontent-block {
        border-radius: .5rem;
    }
}

@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;
        font-family: var(--body-font-family);
        font-weight: 700;
    }
    .g-main-nav .g-sublevel>li>.g-menu-item-container>.g-menu-item-content>.g-menu-item-title {
        font-size: 1.25vw;
        font-family: var(--body-font-family);
        font-weight: 700;
    }

    .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(--primary-color);
        font-size: 1.5vw;
    }
    .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;
    }
    #g-navigation .nav-logo-icon {
        display: none!important;
    }
    .ql-fa-toplinks .g-blockcontent-subcontent-block-content > .g-blockcontent-subcontent-title {
        display: flex;
    }
    .ql-fa-toplinks .g-blockcontent-subcontent-title-text {
        color: var(--default-white);
    }
}
/*************** SLIDESHOW ****************/ 
@media only screen and (min-width: 50.99rem) {
    .fullwidth-swiper.square-pager .g-swiper.swiper-container-horizontal>.swiper-pagination-bullets {
        bottom: 1rem;
        left: 3rem;
        transform: unset;
        gap: 1vw;
    }
    .fullwidth-swiper.square-pager .g-swiper.swiper-container-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet::after {
        border-radius: 0;
        display: none!important;
    }
    .fullwidth-swiper.square-pager .g-swiper.swiper-container-vertical>.swiper-pagination-bullets .swiper-pagination-bullet::after {
        border-radius: 0;
        display: none!important;
    }
    .fullwidth-swiper.square-pager .g-swiper.swiper-container-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet {
        margin: 0;
        padding: 0;
        border-radius: 0;
        border: 0;
        box-shadow: var(--default-box-shadow);
    }
    .fullwidth-swiper.square-pager .g-swiper.swiper-container-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet {
        margin: 0;
        padding: 0;
        border-radius: 0;
        border: 0;
        box-shadow: var(--default-box-shadow);
    }
    .fullwidth-swiper.square-pager .g-swiper.swiper-container-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet:not(.swiper-pagination-bullet.swiper-pagination-bullet-active) {
        background: rgba(255,255,255,.5);
    }
}

@media only screen and (min-width: 50.99rem) {
    .swiper-masstimes-overlay .mass-times-overlay {
        top: 1rem;
        bottom: 1rem;
        left: unset;
        right: 4rem;
        height: calc(var(--swiper-height) - 2rem);
        width: 27.5%;
    }

    .swiper-masstimes-overlay .mass-times-overlay :is(h1,h2,h3,h4,h5,h6) {
        text-transform: none;
        font-variant-caps: normal;
        margin-top: .25vw;
        margin-bottom: .5vw;
    }

    .swiper-masstimes-overlay .mass-times-overlay :is(p,li) {
        margin-bottom: .5vw;
        letter-spacing: 1px;
    }
}

@media only screen and (max-width: 50.99rem) {
    .swiper-masstimes-overlay .mass-times-overlay :is(h1,h2,h3,h4,h5,h6) {
        text-transform: none;
        font-variant-caps: normal;
        margin-top: .25vw;
        margin-bottom: .5vw;
    }

    .swiper-masstimes-overlay .mass-times-overlay :is(p,li) {
        margin-bottom: .5vw;
        letter-spacing: 1px;
    }
}

@media only screen and (min-width: 50.99rem) {
    .swiper-masstimes-overlay .swiper-overlay-buttons {
        position: absolute;
        bottom: 5rem;
        left: 3rem;
        z-index: 2;
        width: 20%;
    }
}

@media only screen and (min-width: 50.99rem) {
    .swiper-overlay-buttons {
        margin: 0;
        padding: 0;
        pointer-events: none;
    }
    .swiper-overlay-buttons > .g-content {
        margin: 0;
        padding: 0;
    }
    .swiper-overlay-buttons > .g-content > div {
        margin: 0;
        padding: 0;
    }
    .swiper-overlay-buttons .g-blockcontent {
        margin: 0;
        padding: 0;
    }
    .swiper-overlay-buttons .g-blockcontent-subcontent {
        margin: 0;
        padding: 0;
        display: flex;
        flex-direction: column;
        gap: 1.5vw;
    }
    .swiper-overlay-buttons .g-blockcontent-subcontent-block {
        margin: 0;
        padding: 0;
    }
    .swiper-overlay-buttons .g-blockcontent-subcontent-block-content {
        margin: 0;
        padding: 1vw;
        position: relative;
        display: flex;
        flex-direction: row;
        justify-content: center;
        align-items: center;
        gap: 1vw;
        background: rgba(var(--primary-rgb),.7);
        border: 2px solid var(--default-white);
        border-radius: 4px;
        box-shadow: var(--default-box-shadow);
        transition: .3s all ease-in-out;
        pointer-events: all;
    }
    .swiper-overlay-buttons .g-blockcontent-subcontent-block-content:hover {
        transform: scale(1.05);
        background: rgba(var(--primary-rgb),1);
    }
    .swiper-overlay-buttons .g-blockcontent-subcontent-title {
        margin: 0;
        padding: 0;
        display: flex;
        justify-content: center;
        align-items: center;
    }
    .swiper-overlay-buttons .g-blockcontent-subcontent-title-text {
        margin: 0;
        padding: 0;
        color: var(--default-white);
        font-size: 1.5vw;
        line-height: 1.5vw;
        font-weight: 400;
        text-transform: uppercase;
        font-family: var(--body-font-family);
        font-variant-caps: normal;
    }
    .swiper-overlay-buttons .g-blockcontent-subcontent-title-icon {
        margin: 0;
        padding: 0;
        color: var(--default-white);
        font-size: 1.5vw;
        line-height: 1.5vw;
        display: flex;
        justify-content: center;
        align-items: center;
    }
    .swiper-overlay-buttons .g-blockcontent-buttons {
        margin: 0;
        padding: 0;
        position: absolute;
        top: 0;
        bottom: 0;
        left: 0;
        right: 0;
        height: 100%;
        width: 100%;
        opacity: 0;
    }
    .swiper-overlay-buttons .g-blockcontent-buttons a {
        margin: 0;
        padding: 0;
        position: absolute;
        top: 0;
        bottom: 0;
        left: 0;
        right: 0;
        height: 100%;
        width: 100%;
        opacity: 0;
    }
}

@media only screen and (max-width: 50.99rem) {
    .site-1-home #g-slideshow > .g-container > .g-grid:has(.swiper-overlay-buttons) {
        padding: 1rem!important;
    }
}

@media only screen and (max-width: 50.99rem) {
    .swiper-overlay-buttons {
        margin: 0;
        padding: 0;
        pointer-events: none;
    }
    .swiper-overlay-buttons > .g-content {
        margin: 0;
        padding: 0;
    }
    .swiper-overlay-buttons > .g-content > div {
        margin: 0;
        padding: 0;
    }
    .swiper-overlay-buttons .g-blockcontent {
        margin: 0;
        padding: 0;
    }
    .swiper-overlay-buttons .g-blockcontent-subcontent {
        margin: 0;
        padding: 0;
        display: flex;
        flex-direction: column;
        gap: 1rem;
    }
    .swiper-overlay-buttons .g-blockcontent-subcontent-block {
        margin: 0;
        padding: 0;
    }
    .swiper-overlay-buttons .g-blockcontent-subcontent-block-content {
        margin: 0;
        padding: 1rem;
        position: relative;
        display: flex;
        flex-direction: row;
        justify-content: center;
        align-items: center;
        gap: 1rem;
        background: rgba(var(--primary-rgb),.7);
        border: 2px solid var(--default-white);
        border-radius: 4px;
        box-shadow: var(--default-box-shadow);
        transition: .3s all ease-in-out;
        pointer-events: all;
    }
    .swiper-overlay-buttons .g-blockcontent-subcontent-block-content:hover {
        transform: scale(1.05);
        background: rgba(var(--primary-rgb),1);
    }
    .swiper-overlay-buttons .g-blockcontent-subcontent-title {
        margin: 0;
        padding: 0;
        display: flex;
        justify-content: center;
        align-items: center;
    }
    .swiper-overlay-buttons .g-blockcontent-subcontent-title-text {
        margin: 0;
        padding: 0;
        color: var(--default-white);
        font-size: 6vw;
        line-height: 6vw;
        font-weight: 400;
        text-transform: uppercase;
        font-family: var(--body-font-family);
        font-variant-caps: normal;
    }
    .swiper-overlay-buttons .g-blockcontent-subcontent-title-icon {
        margin: 0;
        padding: 0;
        color: var(--default-white);
        font-size: 6.5vw;
        line-height: 6.5vw;
        display: flex;
        justify-content: center;
        align-items: center;
    }
    .swiper-overlay-buttons .g-blockcontent-buttons {
        margin: 0;
        padding: 0;
        position: absolute;
        top: 0;
        bottom: 0;
        left: 0;
        right: 0;
        height: 100%;
        width: 100%;
        opacity: 0;
    }
    .swiper-overlay-buttons .g-blockcontent-buttons a {
        margin: 0;
        padding: 0;
        position: absolute;
        top: 0;
        bottom: 0;
        left: 0;
        right: 0;
        height: 100%;
        width: 100%;
        opacity: 0;
    }
}

/*************** HEADER *******************/
/*  */
@media only screen and (min-width: 50.99rem) {
    .site-1-home #g-header > .g-container {
        padding: 3vw 5%!important;
    }
}

@media only screen and (max-width: 50.99rem) {
    .site-1-home #g-header > .g-container {
        padding: 2rem 1rem!important;
    }
    .site-1-home .ph-sidebyside-mobile .g-title {
        text-align: center;
    }
}

@media only screen and (min-width: 50.99rem) {
    .ph-boxes-spread {
        margin: 0;
        padding: 0;
    }
    .ph-boxes-spread .g-title {
        border: none;
        margin: 0 0 2vw 0;
        padding: 0 0 1vw 0;
        font-size: 2.25vw;
        line-height: 2.25vw;
        letter-spacing: 1px;
        font-family: var(--body-font-family);
        font-weight: 700;
        text-transform: uppercase;
        font-variant-caps: normal;
        color: var(--default-black);
        border-bottom: 2px solid var(--default-black);
    }
    .ph-boxes-spread > .g-content {
        margin: 0;
        padding: 0;
    }
    .ph-boxes-spread > .g-content > div {
        margin: 0;
        padding: 0;
    }
    .ph-boxes-spread .g-content-array {
        margin: 0;
        padding: 0;
        display: flex;
        flex-direction: row;
        justify-content: center;
        gap: 2vw;
    }
    .ph-boxes-spread .g-content-array > .g-grid {
        margin: 0;
        padding: 0;
        flex: 33;
        max-width: 34%;
    }
    .ph-boxes-spread .g-content-array > .g-grid > .g-block {
        margin: 0;
        padding: 0;
    }
    .ph-boxes-spread .g-content-array > .g-grid > .g-block > .g-content {
        margin: 0;
        padding: 0;
    }
    .ph-boxes-spread .g-array-item {
        margin: 0;
        padding: 1vw;
        position: relative;
        display: flex;
        flex-direction: column;
        gap: 1vw;
        border-radius: .5rem;
        transition: .3s all ease-in-out;
    }
    .ph-boxes-spread .g-array-item:hover {
        background: rgba(var(--primary-rgb),.25);
    }
    .ph-boxes-spread .g-array-item:hover .g-array-item-image {
        transform: scale(1.05);
    }
    .ph-boxes-spread .g-array-item-image {
        margin: 0;
        padding: 0;
        aspect-ratio: 16 / 9;
        border: 2px solid var(--default-white);
        border-radius: .5rem;
        box-shadow: var(--default-box-shadow);
        overflow: hidden;
        transition: .3s all ease-in-out;
    }
    .ph-boxes-spread .g-array-item-image a {
        margin: 0;
        padding: 0;
    }
    .ph-boxes-spread .g-array-item-image img {
        margin: 0;
        padding: 0;
        height: 100%;
        width: 100%;
        object-position: center;
        object-fit: cover;
        transition: .3s all ease-in-out;
    }
    .ph-boxes-spread .g-array-item-title {
        margin: 0;
        padding: 0;
    }
    .ph-boxes-spread .g-item-title {
        margin: 0;
        padding: 0;
        border: none;
    }
    .ph-boxes-spread .g-item-title a {
        margin: 0;
        padding: 0;
        color: var(--default-black);
        font-weight: 700;
        font-size: 2vw;
        font-variant-caps: normal;
        text-transform: normal;
    }
    .ph-boxes-spread .g-array-item-text {
        margin: 0;
        padding: 0;
        color: var(--default-black);
        font-size: 1.25vw;
    }
    .ph-boxes-spread .g-array-item-read-more {
        margin: 0;
        padding: 0;
        position: absolute;
        top: 0;
        bottom: 0;
        left: 0;
        right: 0;
        height: 100%;
        width: 100%;
        opacity: 0;
    }
    .ph-boxes-spread .g-array-item-read-more a {
        margin: 0;
        padding: 0;
        position: absolute;
        top: 0;
        bottom: 0;
        left: 0;
        right: 0;
        height: 100%;
        width: 100%;
        opacity: 0;
    }
}

@media only screen and (min-width: 50.99rem) {
    .home-news-button .button {
        color: var(--default-white);
        background: var(--primary-color);
        border: 2px solid var(--default-white);
        border-radius: .25rem;
        box-shadow: var(--default-box-shadow);
        padding: .75vw 4vw;
        text-transform: uppercase;
        font-variant-caps: normal;
        font-size: 1.25vw;
        line-height: 1.25vw;
        font-weight: 700;
        transition: .3s all ease-in-out;
    }
    .home-news-button .button:hover {
        background: #777;
        color: var(--default-white);
    }
}

/*************** ABOVE ********************/
@media only screen and (min-width: 50.99rem) {
    .site-1-home #g-above > .g-container {
        padding: 3vw 5%!important;
        display: flex;
        flex-direction: column;
        gap: 2vw;
    }
}

@media only screen and (max-width: 50.99rem) {
    .site-1-home #g-above > .g-container {
        padding: 2rem 1rem!important;
        display: flex;
        flex-direction: column;
        gap: 1rem;
    }
}

@media only screen and (min-width: 50.99rem) {
    .rok-mini-calendar-badge .g-title {
        border: none;
        margin: 0 0 2vw 0;
        padding: 0 0 1vw 0;
        font-size: 2.25vw;
        line-height: 2.25vw;
        letter-spacing: 1px;
        font-family: var(--body-font-family);
        font-weight: 700;
        text-transform: uppercase;
        font-variant-caps: normal;
        color: var(--default-white);
        border-bottom: 2px solid var(--default-white);
    }
}

@media only screen and (max-width: 50.99rem) {
    .rok-mini-calendar-badge .g-title {
        border: none;
        margin: 0 0 2rem 0;
        padding: 0 0 1rem 0;
        font-size: 2.25rem;
        line-height: 2.25rem;
        letter-spacing: 1px;
        font-family: var(--body-font-family);
        font-weight: 700;
        text-transform: uppercase;
        font-variant-caps: normal;
        color: var(--default-white);
        border-bottom: 2px solid var(--default-white);
        text-align: center;
    }
}

@media only screen and (min-width: 50.99rem) {
    .rok-mini-calendar-badge {
        margin: 0;
        padding: 0;
    }
    .rok-mini-calendar-badge > .g-content {
        margin: 0;
        padding: 0;
    }
    .rok-mini-calendar-badge > .g-content > .platform-content {
        margin: 0;
        padding: 0;
    }
    .rok-mini-calendar-badge > .g-content > .platform-content > div {
        margin: 0;
        padding: 0;
        display: flex;
        flex-direction: column;
        justify-content: center;
    }
    .rok-mini-calendar-badge .rokminievents3 {
        margin: 0;
        padding: 0;
        width: 100%;
    }
    .rok-mini-calendar-badge .rme-items {
        margin: 0;
        padding: 1vw 5% 4vw 5%;
        display: flex;
        flex-direction: row;
        gap: .5vw;
    }
    .rok-mini-calendar-badge .rme-item {
        margin: 0;
        padding: 0;
        display: flex;
        flex-direction: column;
        gap: .5vw;
        aspect-ratio: 4 / 3;
        max-width: calc(100% / 6);
    }
    .rok-mini-calendar-badge .rme-badge {
        margin: 0;
        padding: 0;
        display: flex;
        flex-direction: column;
        width: 50%;
        aspect-ratio: 4 / 3;
        display: flex;
        justify-content: center;
        align-items: center;
        border-radius: .5rem;
        box-shadow: var(--default-box-shadow);
        position: relative;
        background: var(--default-white);
        color: var(--default-black);
    }
    .rok-mini-calendar-badge .rme-badge:before {
        content: '';
        position: absolute;
        top: 0;
        left: 20%;
        width: 5%;
        height: 10%;
        background: var(--default-black);
    }
    .rok-mini-calendar-badge .rme-badge:after {
        content: '';
        position: absolute;
        top: 0;
        right: 20%;
        width: 5%;
        height: 10%;
        background: var(--default-black);
    }
    .rok-mini-calendar-badge .rme-day {
        margin: 0;
        padding: 0;
        order: 2;
        font-size: 1.25vw;
        font-weight: 700;
        font-family: var(--title-font-family);
        text-transform: none;
        font-variant-caps: normal;
        letter-spacing: 2px;
        line-height: 1.25vw;
    }
    .rok-mini-calendar-badge .rme-month {
        margin: 0;
        padding: 0;
        order: 1;
        font-size: 1.25vw;
        font-weight: 700;
        font-family: var(--title-font-family);
        text-transform: none;
        font-variant-caps: normal;
        letter-spacing: 2px;
        line-height: 1.25vw;
    }
    .rok-mini-calendar-badge .rme-description {
        margin: 0;
        padding: 0;
        display: flex;
        flex-direction: column;
    }
    .rok-mini-calendar-badge .rme-title {
        margin: 0;
        padding: 0;
        order: 2;
        font-size: 1.25vw;
        font-weight: 400;
        font-family: var(--title-font-family);
        color: var(--default-white);
        letter-spacing: 1px;
    }
    .rok-mini-calendar-badge .rme-time {
        margin: 0;
        padding: 0;
        order: 1;
        font-size: 1.35vw;
        font-weight: 700;
        font-family: var(--title-font-family);
        color: var(--default-white);
        letter-spacing: 1px;
    }
    .rok-mini-calendar-badge .rme-details {
        margin: 0;
        padding: 0;
    }
    .rok-mini-calendar-badge .rme-timeline {
        margin: 0;
        padding: 0;
    }
    .rok-mini-calendar-badge .rme-timeline-bar {
        margin: .5vw 1.5vw;
        padding: 0;
    }
    .rok-mini-calendar-badge .rme-timeline-points {
        margin: 0;
        padding: 0;
    }
    .rok-mini-calendar-badge .rme-timeline-point {
        margin: 0;
        padding: 0;
        height: 1vw;
        line-height: 1vw;
        display: flex;
        justify-content: center;
        align-items: center;
        border-radius: .5vw / 50%;
        /*background: var(--secondary-color);*/
    }
    .rok-mini-calendar-badge .rme-timeline-point.active {
        border-radius: .5vw / 50%;
        background: var(--secondary-color);
    }
    .rok-mini-calendar-badge .rme-timeline-point:hover {
        background: var(--secondary-color);
    }
    .rok-mini-calendar-badge .rme-timeline-point > span {
        margin: 0;
        padding: 0;
        height: 1vw;
        width: 1vw;
        line-height: 1vw;
        display: flex;
        justify-content: center;
        align-items: center;
        background: #ffffff;
    }
    .rok-mini-calendar-badge .rme-timeline-point:hover span, .rok-mini-calendar-badge .rme-timeline-point.active span {
        background: var(--primary-color);
    }
    .rok-mini-calendar-badge .rem-timeline-date {
        margin: 0;
        padding: 0;
    }
    .rok-mini-calendar-badge .rme-arrow {
        margin: 0;
        padding: 0;
        color: var(--default-white);
    }
}

@media only screen and (min-width: 50.99rem) {
    .home-cal-button .button {
        color: var(--default-black);
        background: var(--default-white);
        border-radius: .25rem;
        box-shadow: var(--default-box-shadow);
        padding: .75vw 4vw;
        text-transform: uppercase;
        font-variant-caps: normal;
        font-size: 1.25vw;
        line-height: 1.25vw;
        font-weight: 700;
        transition: .3s all ease-in-out;
    }
    .home-cal-button .button:hover {
        background: #777;
        color: var(--default-white);
    }
}

@media only screen and (max-width: 50.99rem) {
    .home-cal-button .button {
        color: var(--default-black);
        background: var(--default-white);
        border-radius: .5rem;
        box-shadow: var(--default-box-shadow);
        /*padding: .75vw 4vw;*/
        text-transform: uppercase;
        font-variant-caps: normal;
        font-size: 1.25rem;
        line-height: 1.25rem;
        font-weight: 700;
        transition: .3s all ease-in-out;
    }
    .home-cal-button .button:hover {
        background: #777;
        color: var(--default-white);
    }
}

@media only screen and (max-width: 50.99rem) {
    .rok-mini-calendar-badge-mobile {
        margin: 0;
        padding: 0;
    }
    .rok-mini-calendar-badge-mobile > .g-content {
        margin: 0;
        padding: 0;
    }
    .rok-mini-calendar-badge-mobile > .g-content > .platform-content {
        margin: 0;
        padding: 0;
    }
    .rok-mini-calendar-badge-mobile > .g-content > .platform-content > div {
        margin: 0;
        padding: 0;
        display: flex;
        flex-direction: column;
        justify-content: center;
    }
    /*.rok-mini-calendar-badge-mobile .g-title {
        margin: 0;
        padding: 0;
        border-bottom: none;
        border-left: 1rem solid var(--secondary-color);
        margin-bottom: 1vw;
        font-size: 2.5rem;
        letter-spacing: 10px;
        text-transform: uppercase;
        margin: 0 auto 2rem auto;
        padding-left: 2vw;
        line-height: 2.5rem;
        text-shadow: var(--default-text-shadow);
    }*/
    .rok-mini-calendar-badge-mobile .rokminievents3 {
        margin: 0;
        padding: 0;
        width: 100%;
    }
    .rok-mini-calendar-badge-mobile .rme-items {
        margin: 0;
        padding: 1vw 5% 4vw 5%;
        display: flex;
        flex-direction: column;
        gap: 1rem;
    }
    .rok-mini-calendar-badge-mobile .rme-item {
        margin: 0;
        padding: 0;
        display: flex;
        flex-direction: row;
        gap: 1rem;
    }
    .rok-mini-calendar-badge-mobile .rme-badge {
        margin: 0;
        padding: 0;
        display: flex;
        flex-direction: column;
        flex: 34;
        width: 34%;
        height: 24vw;
        display: flex;
        justify-content: center;
        align-items: center;
        border-radius: 1rem;
        box-shadow: var(--default-box-shadow);
        position: relative;
        background: var(--default-white);
    }
    .rok-mini-calendar-badge-mobile .rme-badge:before {
        content: '';
        position: absolute;
        top: 0;
        left: 20%;
        width: 5%;
        height: 10%;
        background: var(--default-black);
    }
    .rok-mini-calendar-badge-mobile .rme-badge:after {
        content: '';
        position: absolute;
        top: 0;
        right: 20%;
        width: 5%;
        height: 10%;
        background: var(--default-black);
    }
    .rok-mini-calendar-badge-mobile .rme-day {
        margin: 0;
        padding: 0;
        order: 2;
        font-size: 1.25rem;
        font-weight: 700;
        font-family: var(--title-font-family);
        text-transform: none;
        font-variant-caps: normal;
        letter-spacing: 2px;
        line-height: 1.25rem;
        color: var(--default-black);
    }
    .rok-mini-calendar-badge-mobile .rme-month {
        margin: 0;
        padding: 0;
        order: 1;
        font-size: 1.25rem;
        font-weight: 700;
        font-family: var(--title-font-family);
        text-transform: none;
        font-variant-caps: normal;
        letter-spacing: 2px;
        line-height: 1.25rem;
        color: var(--default-black);
    }
    .rok-mini-calendar-badge-mobile .rme-description {
        margin: 0;
        padding: 0;
        display: flex;
        flex-direction: column;
        justify-content: center;
        flex: 66%;
    }
    .rok-mini-calendar-badge-mobile .rme-title {
        margin: 0;
        padding: 0;
        order: 2;
        font-size: 1rem;
        font-weight: 400;
        font-family: var(--title-font-family);
        color: var(--default-white);
    }
    .rok-mini-calendar-badge-mobile .rme-time {
        margin: 0;
        padding: 0;
        order: 1;
        font-size: 1rem;
        font-weight: 700;
        font-family: var(--title-font-family);
        color: var(--default-white);
    }
    .rok-mini-calendar-badge-mobile .rme-details {
        margin: 0;
        padding: 0;
    }
    .rok-mini-calendar-badge-mobile .rme-timeline {
        margin: 0;
        padding: 0;
    }
    .rok-mini-calendar-badge-mobile .rme-timeline-bar {
        margin: .5vw 1vw;
        padding: 0;
    }
    .rok-mini-calendar-badge-mobile .rme-timeline-points {
        margin: 0;
        padding: 0;
    }
    .rok-mini-calendar-badge-mobile .rme-timeline-point {
        margin: 0;
        padding: 0;
        height: 1vw;
        line-height: 1vw;
        display: flex;
        justify-content: center;
        align-items: center;
        border-radius: .5vw / 50%;
        /*background: var(--secondary-color);*/
    }
    .rok-mini-calendar-badge-mobile .rme-timeline-point.active {
        border-radius: .5vw / 50%;
        background: var(--secondary-color);
    }
    .rok-mini-calendar-badge-mobile .rme-timeline-point:hover {
        background: var(--secondary-color);
    }
    .rok-mini-calendar-badge-mobile .rme-timeline-point > span {
        margin: 0;
        padding: 0;
        height: 1vw;
        width: 1vw;
        line-height: 1vw;
        display: flex;
        justify-content: center;
        align-items: center;
    }
    .rok-mini-calendar-badge-mobile .rem-timeline-date {
        margin: 0;
        padding: 0;
    }
    .rok-mini-calendar-badge-mobile .rme-arrow {
        margin: 0;
        padding: 0;
    }
}

/*************** SHOWCASE *****************/
/*************** UTILITY ******************/
/*  */
@media only screen and (min-width: 50.99rem) {
    .site-1-home #g-utility > .g-container {
        padding: 2vw 5%!important;
        display: flex;
        flex-direction: column;
        gap: 2vw;
    }
    .site-1-home #g-utility > .g-container > .g-grid:last-child {
        gap: 4vw;
    }
}

@media only screen and (min-width: 50.99rem) {
    .sm-title-box {
        display: flex;
        flex-direction: row;
        justify-content: space-between;
        align-items: flex-end;
        border-bottom: 2px solid var(--default-black);
        padding-bottom: 1vw;
    }
    .sm-title-text {
        display: flex;
        justify-content: center;
        align-items: center;
    }
    .sm-title-text .g-title {
        border: none;
        margin: 0;
        padding: 0;
        font-size: 2.25vw;
        line-height: 2.25vw;
        letter-spacing: 1px;
        font-family: var(--body-font-family);
        font-weight: 700;
        text-transform: uppercase;
        font-variant-caps: normal;
        color: var(--default-black);
    }
    .sm-social-icons {
        background: var(--primary-color);
        border-radius: .5rem;
        padding: .75vw 1.5vw;
        margin-right: 1vw;
    }
    .sm-social-icons .g-social-items {
        display: flex;
        flex-direction: row;
        gap: 1.5vw;
    }
    .sm-social-icons .g-social-items a {
        color: var(--default-white);
        font-size: 3vw;
        line-height: 3vw;
        transition: .3s all ease-in-out;
    }
    .sm-social-icons .g-social-items a:hover {
        color: #abacab;
    }
}

@media only screen and (max-width: 50.99rem) {
    .site-1-home #g-utility > .g-container {
        padding: 1rem 15%!important;
        display: flex;
        flex-direction: column;
        gap: 1rem;
    }
    .site-1-home #g-utility > .g-container > .g-grid:last-child {
        gap: 1rem;
    }
}

@media only screen and (max-width: 50.99rem) {
    .sm-title-box {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        border-bottom: 2px solid var(--default-black);
        padding-bottom: 1rem;
        gap: 1rem;
    }
    .sm-title-text {
        display: flex;
        justify-content: center;
        align-items: center;
    }
    .sm-title-text .g-title {
        border: none;
        margin: 0;
        padding: 0;
        font-size: 1.5rem;
        line-height: 1.5rem;
        letter-spacing: 1px;
        font-family: var(--body-font-family);
        font-weight: 700;
        text-transform: uppercase;
        font-variant-caps: normal;
        color: var(--default-black);
        text-align: center;
    }
    .sm-social-icons {
        background: var(--primary-color);
        border-radius: .5rem;
        padding: .25rem 1rem;
        margin-right: 1vw;
    }
    .sm-social-icons .g-social-items {
        display: flex;
        flex-direction: row;
        gap: 1.5rem;
    }
    .sm-social-icons .g-social-items a {
        color: var(--default-white);
        font-size: 2rem;
        line-height: 2rem;
        transition: .3s all ease-in-out;
    }
    .sm-social-icons .g-social-items a:hover {
        color: #abacab;
    }
}

@media only screen and (min-width: 50.99rem) {
    .header-social-boxes {
        width: calc(50% - 2vw);
        flex: 0 calc(50% - 2vw);
        max-width: 50%;
    }
    .header-social-boxes .g-array-item-text {
        margin: 0;
        padding: 0;
    }
    .header-social-boxes :is(.fb-social-box, .ig-social-box) {
        border-radius: 1rem;
        overflow: hidden;
        box-shadow: var(--default-box-shadow);
    }
}

@media only screen and (max-width: 50.99rem) {
    .header-social-boxes .g-array-item-text {
        margin: 0;
        padding: 0;
    }
    .header-social-boxes :is(.fb-social-box, .ig-social-box) {
        border-radius: 1rem;
        overflow: hidden;
        box-shadow: var(--default-box-shadow);
    }
}

/*************** FEATURE ******************/
/*************** MAIN *********************/
.parish-home #g-container-main {
    padding: 0 5%;
}

@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;
    }
    .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: .5;} 
#g-footer .g-array-item-text {
    padding: 0;
}

@media only screen and (min-width: 50.99rem) {
    .site-1 #g-container-footer {
        background: url('/images/template/footer.jpg') 50% 42% no-repeat;
        background-size: cover;
    }
    .site-1 #g-footer > .g-container {
        padding: 3vw 5% 5vw 5%!important;
    }
}

@media only screen and (max-width: 50.99rem) {
    .site-1 #g-container-footer {
        background: url('/images/template/footer.jpg') 50% 42% no-repeat;
        background-size: cover;
    }
    .site-1 #g-footer > .g-container {
        padding: 2rem 1rem 5rem 1rem!important;
    }
}

@media only screen and (min-width: 50.99rem) {
    .footer-wrapper {
        display: flex;
        flex-direction: row;
    }
    .footer-info {
        flex: 7;
        display: flex;
        flex-direction: row;
        align-items: flex-end;
        gap: 1vw;
    }
    .footer-logo {
        flex: 3;
        display: flex;
        justify-content: flex-end;
        align-items: flex-end;
    }
}

/*************** 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(--tertiary-color);
} 

.side-menu-particle {
    box-shadow: var(--default-box-shadow);
}

.side-menu-particle .g-blockcontent-subcontent-block.active .g-blockcontent-subcontent-title-text {
    color: var(--primary-color);
}
.side-menu-particle .g-blockcontent-subcontent-block:hover .g-blockcontent-subcontent-title-text {
    color: var(--primary-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;
    }
}