
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans:wght@100;150;200;250;300;350;400;450;500;600;700;800;900&display=block');
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@100;150;200;250;300;350;400;450;500;600;700;800;900&display=block');
@import url('https://fonts.googleapis.com/css2?family=Open+Sans:wght@100;150;200;250;300;350;400;450;500;600;700;800;900&display=block');
@import url('https://fonts.googleapis.com/css2?family=Google+Sans:wght@100;150;200;250;300;350;400;450;500;600;700;800;900&display=block');
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@100;150;200;250;300;350;400;450;500;600;700;800;900&display=block');
@import url('https://fonts.googleapis.com/css2?family=Raleway:wght@100;150;200;250;300;350;400;450;500;600;700;800;900&display=block');
@import url('https://fonts.googleapis.com/css2?family=Quicksand:wght@100;150;200;250;300;350;400;450;500;600;700;800;900&display=block');
@import url('https://fonts.googleapis.com/css2?family=Figtree:wght@100;150;200;250;300;350;400;450;500;600;700;800;900&display=block');

@import url('https://fonts.googleapis.com/css2?family=Noto+Serif:wght@100;150;200;250;300;350;400;450;500;600;700;800;900&display=block');
@import url('https://fonts.googleapis.com/css2?family=Lora:wght@100;150;200;250;300;350;400;450;500;600;700;800;900&display=block');
@import url('https://fonts.googleapis.com/css2?family=PT+Serif:wght@100;150;200;250;300;350;400;450;500;600;700;800;900&display=block');
@import url('https://fonts.googleapis.com/css2?family=Bitter:wght@100;150;200;250;300;350;400;450;500;600;700;800;900&display=block');
@import url('https://fonts.googleapis.com/css2?family=EB+Garamond:wght@100;150;200;250;300;350;400;450;500;600;700;800;900&display=block');
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@100;150;200;250;300;350;400;450;500;600;700;800;900&display=block');

html, body 
{
    display:block;
    min-height:100vh;
    margin:0px;
    color:#282828;
    -webkit-tap-highlight-color:transparent;
    -webkit-tap-highlight-color:rgba(0, 0, 0, 0);
}
@media screen and (min-width: 768px)
{
    html, body 
    {
        display:flex;
        flex-direction:column;
        min-height:100vh;
        margin:0px;
        color:#282828;
        -webkit-tap-highlight-color:transparent;
        -webkit-tap-highlight-color:rgba(0, 0, 0, 0);
    }
}

a
{
    text-decoration:none;
    color:inherit;
    cursor:pointer;
}

a:hover
{
    text-decoration:underline;
}

a.nohover
{
    text-decoration:none;
}

.hover-underline:hover
{
    text-decoration:underline !important;
}

h1
{
    margin-top:0px;
    font-size:24px;
    line-height:1.2;
    font-weight:600;
}

h2
{
    margin-top:0px;
    font-size:22px;
    line-height:1.2;
    font-weight:600;
}

h3
{
    margin-top:0px;
    font-size:20px;
    line-height:1.2;
    font-weight:600;
}

.text-blue
{
    color:#0084D6;
}

.link-blue a
{
    color:#0084D6;
}

button
{
    appearance: none;
    -webkit-appearance: none;
    background: transparent;
    border: none;
    padding: 0;
    margin: 0;
}

input:focus
{
	outline:0;
}

.gen-textarea
{
	width:95%;
	height:200px;
	padding:10px;
	box-sizing:border-box;
	border-collapse:separate;
	border-radius:4px;
	font-family:unset;
	font-size:17px;
	color:#282828;
	border:1px solid #B0B0B0;
	box-shadow:0px 0px 3px 0px #D9D9D9;
	outline:none;
}
@media screen and (min-width: 768px)
{
    .gen-textarea
    {
    	width:70%;
    	height:200px;
    	padding:10px;
    	box-sizing:border-box;
    	border-collapse:separate;
    	border-radius:4px;
    	font-family:unset;
    	font-size:17px;
    	color:#282828;
    	border:1px solid #B0B0B0;
    	box-shadow:0px 0px 3px 0px #D9D9D9;
    	outline:none;
    }
}

.gen-textarea:focus
{
	border:1px solid #0084D6;
}

.gen-input
{
	width:200px;
	height:30px;
	padding-left:6px;
	box-sizing:border-box;
	border-collapse:separate;
	border-radius:4px;
	font-family:unset;
	font-size:15px;
	color:#282828;
	border:1px solid #B0B0B0;
	box-shadow:0px 0px 3px 0px #D9D9D9;
}

.gen-input:focus
{
	border:2px solid #0084D6;
	padding-left:5px;
}

.gen-input-label
{
    font-weight:500;
    color:#484848;
}

.form-wrapper
{
	display:flex;
	flex-direction:column;
	align-items:center;
	gap:24px;
	margin-top:10px;
}

.input-container
{
	position:relative;
	display:block;
	width:90%;
}
@media screen and (min-width: 768px)
{
    .input-container
    {
    	position:relative;
    	display:block;
    	width:350px;
    }
}

.gen-input-large
{
	width:100%;
	height:45px;
	padding-left:10px;
	box-sizing:border-box;
	border-collapse:separate;
	border-radius:4px;
	font-family:unset;
	font-size:20px;
	color:#282828;
	border:1px solid #B0B0B0;
	box-shadow:0px 0px 3px 0px #D9D9D9;
	outline:none;
}

.input-container label
{
	position:absolute;
	left:10px;
	top:12px;
	color:#999;
	transition:0.2s ease all;
	pointer-events:none;
	font-size:20px;
}

.gen-input-large:focus ~ label,
.gen-input-large:not(:placeholder-shown) ~ label
{
	top:-10px;
	left:8px;
	font-size:14px;
	color:#2196F3;
	background-color:#FFFFFF;
	padding:0 4px;
}

.gen-input-large:focus
{
	border:1px solid #2196F3;
	box-shadow:0px 0px 5px 0px rgba(33, 150, 243, 0.3);
}

.date-input
{
	width:auto;
	min-width:80px;
	height:40px;
	padding-left:10px;
	padding-right:5px;
	box-sizing:border-box;
	border-collapse:separate;
	border-radius:4px;
	font-family:unset;
	font-size:18px;
	color:#282828;
	border:1px solid #B0B0B0;
	box-shadow:0px 0px 3px 0px #D9D9D9;
	outline:none;
	background-color:#FFFFFF;
	cursor:pointer;
}

.date-input:focus
{
	border:1px solid #2196F3;
	box-shadow:0px 0px 5px 0px rgba(33, 150, 243, 0.3);
}

.date-input-blue
{    
    color:#0084D6;
}

.date-input::-webkit-calendar-picker-indicator
{
	margin-left:5px;
	transform:scale(1.2);
	cursor:pointer;
}

.time-input
{
	width:auto;
	height:40px;
	padding-left:10px;
	padding-right:5px;
	box-sizing:border-box;
	border-collapse:separate;
	border-radius:4px;
	font-family:unset;
	font-size:18px;
	color:#282828;
	border:1px solid #B0B0B0;
	box-shadow:0px 0px 3px 0px #D9D9D9;
	outline:none;
	background-color:#FFFFFF;
	cursor:pointer;
	appearance:auto;
	-webkit-appearance:auto;
}

.time-input:focus
{
	border:1px solid #2196F3;
	box-shadow:0px 0px 5px 0px rgba(33, 150, 243, 0.3);
}

.gen-dialog
{
    max-width:50%;
    margin-top:25vh;
    margin-bottom:auto;
    max-height: 70vh;
    overflow-y: auto;
    text-align:center;
    padding:20px;
    border:3px solid rgba(0, 132, 214, 0.6);
    border-radius:8px;
	box-shadow: 0 0 4px 2px #D9D9D9;
    outline:none;
    box-sizing:border-box;
}

figure
{
    display:inline-block;
    width:100%;
    margin-top:16px;
    margin-bottom:16px;
    margin-left:0;
    margin-right:0;
}

.no-select
{
    user-select:none;
}

#footer
{
    width:88%;
    margin-top:20px;
    padding-left:6%;
    padding-right:6%;
    padding-top:8px;
    padding-bottom:8px;
    text-align:left;
    background-color:#686868;
    color:#D9D9D9;
    font-family:Figtree;
    font-size:15px;
    font-weight:400;
    box-shadow:0 0 4px 2px #A0A0A0;
    opacity:.9;
}
@media screen and (min-width: 768px)
{
    #footer
    {
        width:auto;
        margin-top:20px;
        padding-top:8px;
        padding-bottom:8px;
        text-align:center;
        background-color:#686868;
        color:#D9D9D9;
        font-family:Figtree;
        font-size:15px;
        font-weight:400;
        box-shadow: 0 0 4px 2px #A0A0A0;
        opacity:0.9;
    }
}

.footer-full
{
    display:none;
}
@media screen and (min-width: 768px)
{
    .footer-full
    {
        display:inline;
    }
}

trix-editor
{
    display:block !important;
    background-color:white !important;
    color:#333 !important;
    min-height:400px !important;
    height:auto !important;
    width:90% !important;
    max-width:900px !important;
    margin: 0 auto 20px auto !important;
    padding-top:20px !important;
    padding-bottom:20px !important;
    padding-left:15px !important;
    padding-right:15px !important;
    box-sizing:border-box !important;
}

.admin-content trix-editor
{
    max-width:650px !important;
    margin:0 !important;
    min-height:150px !important;
    font-size:16px !important;
}

trix-editor img
{
    max-width:50%;
    height:auto;
    display:block;
    margin:10px 0;
}

trix-toolbar
{
    position:-webkit-sticky;
    position:sticky;
    top:0;
    z-index:10;
    width:90% !important;
    max-width:900px !important;
    margin: 10px auto 0 auto !important;
    padding-top:10px;
    padding-left:10px;
    padding-right:10px;
    box-sizing:border-box;
    background-color:#f8f9fa;
    border:1px solid #ccc;
    border-bottom:none;
    border-radius:4px 4px 0 0;
}

.admin-content trix-toolbar
{
    max-width:650px !important;
    margin:0 !important;
}

.trix-button--icon-attach::before
{
    content:"";
    display:inline-block;
    width:100%;
    height:100%;
    
    background-color:currentColor;
    -webkit-mask-repeat:no-repeat;
    mask-repeat:no-repeat;
    -webkit-mask-position:center;
    mask-position:center;
    -webkit-mask-size:contain;
    mask-size:contain;
    
    -webkit-mask-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M21 19V5c0-1.1-.9-2-2-2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2zM8.5 13.5l2.5 3.01L14.5 12l4.5 6H5l3.5-4.5z"/></svg>');
    mask-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M21 19V5c0-1.1-.9-2-2-2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2zM8.5 13.5l2.5 3.01L14.5 12l4.5 6H5l3.5-4.5z"/></svg>');
}

button[data-trix-attribute="code"],button[data-trix-attribute="strike"]
{
    display: none !important;
}

.trix-button[data-trix-attribute="underline"],.trix-button[data-trix-attribute="horizontalRule"]
{
    width: 3.4em !important;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    margin: 0;
}

.trix-button[data-trix-attribute="underline"] svg
{
    width: 18px !important;
    height: 18px !important;
    margin: 0 auto !important;
}

.trix-button-group--text-tools
{
  order: 0;
}

.trix-button-group--file-tools
{
  order: 1;
}

.trix-button-group--block-tools
{
  order: 2;
}

.trix-button-group--history-tools
{
  order: 3; 
}

.trix-button-group-spacer
{
  flex-grow: 0 !important;
  width: 0px;
}

.attachment--preview .attachment__caption
{
    display: none !important;
}

.attachment img
{
    max-width:90%;
    height:auto;
    margin-top:0px;
    margin-bottom:0px;
    margin-left:0px;
    box-shadow:0 4px 10px rgba(0, 0, 0, 0.2);
    border-radius:3px;
    transform:translateY(0);
    dynamic-range-limit:standard;
    transition:transform 0.3s ease-out, box-shadow 0.3s ease-out;
}
@media screen and (min-width: 768px)
{
    .attachment img
    {
        max-width:50%;
        height:auto;
        margin-top:0px;
        margin-bottom:0px;
        margin-left:0px;
        box-shadow:0 4px 10px rgba(0, 0, 0, 0.2);
        border-radius:3px;
        transform:translateY(0);
        dynamic-range-limit:standard;
        transition:transform 0.3s ease-out, box-shadow 0.3s ease-out;
    }
}

.attachment--pdf img
{
    width:70px;
    height:70px;
    opacity:.8;
    box-shadow:none;
    transition: filter 0.1s ease, transform 0.1s ease;
}

.attachment:not(.attachment--pdf) img:hover
{
    transform:translateY(-2px); 
    box-shadow:0 20px 40px rgba(0, 0, 0, 0.25);
}
@media screen and (min-width: 768px)
{
    .attachment:not(.attachment--pdf) img:hover
    {
        transform: scale(1.4) translateY(-5px);
        box-shadow:0 40px 60px rgba(0, 0, 0, 0.75); 
    }
}

.attachment--pdf img:hover
{
    opacity:.9;
    filter: drop-shadow(0px 0px 1px rgba(0, 0, 0, 0.3));
    transform: translateY(-2px);
}

trix-editor .attachment img,
trix-editor .attachment img:hover
{
    max-width: 100% !important;
    transform: none !important;
    box-shadow: none !important;
    margin: 0 !important;
    transition: none !important;
    cursor: default !important;
}

[data-trix-attributes*='{"presentation":"gallery"}']:not(.attachment--pdf) figcaption
{
    display: none !important;
}

figure.attachment--pdf figcaption
{
    display: block !important;
    padding: 0;
    margin-top:0px;
    margin-left:8px;
    font-size:15px;
    color:#686868;
}

trix-editor figure.attachment--pdf figcaption
{
    display: block !important;
    padding: 0;
    margin-top:8px;
    margin-left:8px;
}

.attachment__caption.attachment__caption--editing
{
    height:0px;
    margin-top:0px;
}

figure.attachment--pdf .attachment__size
{
    display: none !important;
}

figure.attachment--pdf .attachment__caption
{
    display: block !important;
}

.attachment__metadata
{
    display: none !important;
}

trix-editor .attachment__toolbar
{
    top: 0px !important;
    left: -10px !important;
    right: auto !important;
    width: auto !important;
}

trix-editor .trix-button-group--actions
{
    margin: 0 !important;
}

#header-container
{
    display:flex;
    flex-direction:column;
    align-items:center;
    padding-top:10px;
}
@media screen and (min-width: 768px)
{
    #header-container
    {
        display:flex;
        flex-direction:row;
        justify-content:center;
        align-items:center;
        margin-left:200px;
        margin-right:200px;
        padding-top:10px;
    }
}

#header-logo-cc
{
    display:inline-block;
    vertical-align:middle;
    margin-right:2%;
    padding-top:4px;
    padding-bottom:0px;
    padding-left:8px;
    padding-right:8px;
    background: linear-gradient(#FEFEFE, #FEFEFE) padding-box,
    linear-gradient(135deg, #0084D6, #D6EFFF) border-box;
    border: 2px solid transparent;
    border-radius: 50%;
    box-shadow: 0 0 6px 2px rgba(0, 132, 214, 0.25);
    opacity:.9;
}
@media screen and (min-width: 768px)
{
    #header-logo-cc
    {
        display: inline-block;
        vertical-align: middle;
        margin-right: 30px;
        padding-top:3px;
        padding-bottom:3px;
        padding-left:9px;
        padding-right:9px;
        background: linear-gradient(#FEFEFE, #FEFEFE) padding-box,
        linear-gradient(135deg, #0084D6, #D6EFFF) border-box;
        border: 3px solid transparent;
        border-radius: 50%;
        box-shadow: 0 0 12px 2px rgba(0, 132, 214, 0.25);
        opacity:.9;
    }
}

#header-logo-img-cc
{
    width:50px;
}
@media screen and (min-width: 768px)
{
    #header-logo-img-cc
    {
        width:80px;
    }
}

#header-logo-img-cc-small
{
    width:50px;
}
@media screen and (min-width: 768px)
{
    #header-logo-img-cc-small
    {
        width:50px;
    }
}

#header-logo-custom
{
    display:inline-block;
    vertical-align:middle;
    padding-top:5px;
    padding-bottom:2px;
}
@media screen and (min-width: 768px)
{
    #header-logo-custom
    {
        display:inline-block;
        vertical-align:middle;
        margin-right:20px;
        padding-top:15px;
        padding-bottom:15px;
        padding-left:10px;
        padding-right:10px;
    }
}

#header-logo-img-custom
{
    height:50px;
}
@media screen and (min-width: 768px)
{
    #header-logo-img-custom
    {
        height:60px;
    }
}

#header-text
{
    display:block;
    margin:0px auto 0;
    width:98%;
    text-align:center;
    font-size:clamp(22px, 10vw, 34px);
    font-weight:500;
}
@media screen and (min-width: 768px)
{
    #header-text
    {
        display:inline-block;
        width:auto;
        vertical-align:middle;
        margin:0;
        font-size:58px;
        font-weight:500;
        text-align:left;
    }
}

#header-text-small
{
    display:block;
    margin:0px auto 0;
    width:98%;
    text-align:center;
    font-size:clamp(22px, 10vw, 34px);
    font-weight:500;
}
@media screen and (min-width: 768px)
{
    #header-text-small
    {
        display:inline-block;
        width:auto;
        vertical-align:middle;
        margin:0;
        font-size:54px;
        font-weight:500;
        text-align:left;
    }
}

.header-notification
{
    padding-top:10px;
    padding-bottom:10px;
    padding-left:5%;
    padding-right:5%;
    font-size:17px;
    font-weight:500;
    text-align:center;
    background-color:#EBF7FF;
    box-shadow: 0 0 3px 0px #D9D9D9;
}

.header-error
{
    padding-top:10px;
    padding-bottom:10px;
    padding-left:5%;
    padding-right:5%;
    font-size:17px;
    font-weight:500;
    text-align:center;
    background-color:#FF7676;
    box-shadow: 0 0 3px 0px #D9D9D9;
}

.header-right
{
    display:none;
}
@media screen and (min-width: 768px)
{
    .header-right
    {
        display:block;
        position:absolute;
        right:30px;
        top:10px;
        text-align:right;
    }
}

.header-top-mobile
{
    display:block;
    text-align:center;
    margin-top:10px;
}
@media screen and (min-width: 768px)
{
    .header-top-mobile
    {
        display:none;
    }
}

.header-right-mobile
{
    display:block;
    text-align:center;
    margin-top:-10px;
    margin-bottom:20px;
}
@media screen and (min-width: 768px)
{
    .header-right-mobile
    {
        display:none;
    }
}

.header-right-welcome
{
    margin-bottom:6px;
    padding-left:4px;
    padding-right:4px;
    font-size:17px;
    font-weight:500;
    border-bottom:2px dotted #0084D6;
    cursor:default;
}

.icon-gear
{
    display: inline-block;
    vertical-align:text-top;
    margin-top:-3px;
    margin-right:6px;
    margin-left:-6px;
    width: 26px;
    height: 26px;
    -webkit-mask-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9Ii0yIC0yIDI4IDI4Ij48cGF0aCBkPSJNMTkuNDMgMTIuOThjLjA0LS4zMi4wNy0uNjQuMDctLjk4cy0uMDMtLjY2LS4wNy0uOThsMi4xMS0xLjY1Yy4xOS0uMTUuMjQtLjQyLjEyLS42NGwtMi0zLjQ2Yy0uMTItLjIyLS4zOS0uMzEtLjYxLS4yMmwtMi40OSAxYy0uNTItLjQtMS4wOC0uNzMtMS42OS0uOThsLS4zOC0yLjY1QTEuMDAzIDEuMDAzIDAgMDAxNCAyaC00Yy0uNTIgMC0uOTYuMzktMS4wMS44N2wtLjM4IDIuNjVjLS42MS4yNS0xLjE3LjU5LTEuNjkuOThsLTIuNDktMWMtLjIyLS4wOS0uNDkgMC0uNjEuMjJsLTIgMy40NmMtLjEyLjIyLS4wNy40OS4xMi42NGwyLjExIDEuNjVjLS4wNC4zMi0uMDcuNjUtLjA3Ljk4cy4wMy42Ni4wNy45OGwtMi4xMSAxLjY1Yy0uMTkuMTUtLjI0LjQyLS4xMi42NGwyIDMuNDZjLjEyLjIyLjM5LjMxLjYxLjIybDIuNDktMWMuNTIuNCAxLjA4LjczIDEuNjkuOThsLjM4IDIuNjVjLjA1LjQ4LjQ5Ljg3IDEuMDEuODdoNGMuNTIgMCAuOTYtLjM5IDEuMDEtLjg3bC4zOC0yLjY1Yy42MS0uMjUgMS4xNy0uNTkgMS42OS0uOThsMi40OSAxYy4yMi4wOS40OSAwIC42MS0uMjJsMi0zLjQ2Yy4xMi0uMjIuMDctLjQ5LS4xMi0uNjRsLTIuMTEtMS42NXpNMTIgMTUuNWMtMS45MyAwLTMuNS0xLjU3LTMuNS0zLjVzMS41Ny0zLjUgMy41LTMuNSAzLjUgMS41NyAzLjUgMy41LTEuNTcgMy41LTMuNSAzLjV6Ii8+PC9zdmc+");
    mask-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9Ii0yIC0yIDI4IDI4Ij48cGF0aCBkPSJNMTkuNDMgMTIuOThjLjA0LS4zMi4wNy0uNjQuMDctLjk4cy0uMDMtLjY2LS4wNy0uOThsMi4xMS0xLjY1Yy4xOS0uMTUuMjQtLjQyLjEyLS42NGwtMi0zLjQ2Yy0uMTItLjIyLS4zOS0uMzEtLjYxLS4yMmwtMi40OSAxYy0uNTItLjQtMS4wOC0uNzMtMS42OS0uOThsLS4zOC0yLjY1QTEuMDAzIDEuMDAzIDAgMDAxNCAyaC00Yy0uNTIgMC0uOTYuMzktMS4wMS44N2wtLjM4IDIuNjVjLS42MS4yNS0xLjE3LjU5LTEuNjkuOThsLTIuNDktMWMtLjIyLS4wOS0uNDkgMC0uNjEuMjJsLTIgMy40NmMtLjEyLjIyLS4wNy40OS4xMi42NGwyLjExIDEuNjVjLS4wNC4zMi0uMDcuNjUtLjA3Ljk4cy4wMy42Ni4wNy45OGwtMi4xMSAxLjY1Yy0uMTkuMTUtLjI0LjQyLS4xMi42NGwyIDMuNDZjLjEyLjIyLjM5LjMxLjYxLjIybDIuNDktMWMuNTIuNCAxLjA4LjczIDEuNjkuOThsLjM4IDIuNjVjLjA1LjQ4LjQ5Ljg3IDEuMDEuODdoNGMuNTIgMCAuOTYtLjM5IDEuMDEtLjg3bC4zOC0yLjY1Yy42MS0uMjUgMS4xNy0uNTkgMS42OS0uOThsMi40OSAxYy4yMi4wOS40OSAwIC42MS0uMjJsMi0zLjQ2Yy4xMi0uMjIuMDctLjQ5LS4xMi0uNjRsLTIuMTEtMS42NXpNMTIgMTUuNWMtMS45MyAwLTMuNS0xLjU3LTMuNS0zLjVzMS41Ny0zLjUgMy41LTMuNSAzLjUgMS41NyAzLjUgMy41LTEuNTcgMy41LTMuNSAzLjV6Ii8+PC9zdmc+");
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    background-color:#282828;
    transition: background-color 0.3s ease;
}
@media screen and (min-width: 768px)
{
    .icon-gear
    {
        display: inline-block;
        vertical-align:text-top;
        margin-top:-2px;
        margin-right:6px;
        margin-left:-6px;
        width: 22px;
        height: 22px;
        -webkit-mask-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9Ii0yIC0yIDI4IDI4Ij48cGF0aCBkPSJNMTkuNDMgMTIuOThjLjA0LS4zMi4wNy0uNjQuMDctLjk4cy0uMDMtLjY2LS4wNy0uOThsMi4xMS0xLjY1Yy4xOS0uMTUuMjQtLjQyLjEyLS42NGwtMi0zLjQ2Yy0uMTItLjIyLS4zOS0uMzEtLjYxLS4yMmwtMi40OSAxYy0uNTItLjQtMS4wOC0uNzMtMS42OS0uOThsLS4zOC0yLjY1QTEuMDAzIDEuMDAzIDAgMDAxNCAyaC00Yy0uNTIgMC0uOTYuMzktMS4wMS44N2wtLjM4IDIuNjVjLS42MS4yNS0xLjE3LjU5LTEuNjkuOThsLTIuNDktMWMtLjIyLS4wOS0uNDkgMC0uNjEuMjJsLTIgMy40NmMtLjEyLjIyLS4wNy40OS4xMi42NGwyLjExIDEuNjVjLS4wNC4zMi0uMDcuNjUtLjA3Ljk4cy4wMy42Ni4wNy45OGwtMi4xMSAxLjY1Yy0uMTkuMTUtLjI0LjQyLS4xMi42NGwyIDMuNDZjLjEyLjIyLjM5LjMxLjYxLjIybDIuNDktMWMuNTIuNCAxLjA4LjczIDEuNjkuOThsLjM4IDIuNjVjLjA1LjQ4LjQ5Ljg3IDEuMDEuODdoNGMuNTIgMCAuOTYtLjM5IDEuMDEtLjg3bC4zOC0yLjY1Yy42MS0uMjUgMS4xNy0uNTkgMS42OS0uOThsMi40OSAxYy4yMi4wOS40OSAwIC42MS0uMjJsMi0zLjQ2Yy4xMi0uMjIuMDctLjQ5LS4xMi0uNjRsLTIuMTEtMS42NXpNMTIgMTUuNWMtMS45MyAwLTMuNS0xLjU3LTMuNS0zLjVzMS41Ny0zLjUgMy41LTMuNSAzLjUgMS41NyAzLjUgMy41LTEuNTcgMy41LTMuNSAzLjV6Ii8+PC9zdmc+");
        mask-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9Ii0yIC0yIDI4IDI4Ij48cGF0aCBkPSJNMTkuNDMgMTIuOThjLjA0LS4zMi4wNy0uNjQuMDctLjk4cy0uMDMtLjY2LS4wNy0uOThsMi4xMS0xLjY1Yy4xOS0uMTUuMjQtLjQyLjEyLS42NGwtMi0zLjQ2Yy0uMTItLjIyLS4zOS0uMzEtLjYxLS4yMmwtMi40OSAxYy0uNTItLjQtMS4wOC0uNzMtMS42OS0uOThsLS4zOC0yLjY1QTEuMDAzIDEuMDAzIDAgMDAxNCAyaC00Yy0uNTIgMC0uOTYuMzktMS4wMS44N2wtLjM4IDIuNjVjLS42MS4yNS0xLjE3LjU5LTEuNjkuOThsLTIuNDktMWMtLjIyLS4wOS0uNDkgMC0uNjEuMjJsLTIgMy40NmMtLjEyLjIyLS4wNy40OS4xMi42NGwyLjExIDEuNjVjLS4wNC4zMi0uMDcuNjUtLjA3Ljk4cy4wMy42Ni4wNy45OGwtMi4xMSAxLjY1Yy0uMTkuMTUtLjI0LjQyLS4xMi42NGwyIDMuNDZjLjEyLjIyLjM5LjMxLjYxLjIybDIuNDktMWMuNTIuNCAxLjA4LjczIDEuNjkuOThsLjM4IDIuNjVjLjA1LjQ4LjQ5Ljg3IDEuMDEuODdoNGMuNTIgMCAuOTYtLjM5IDEuMDEtLjg3bC4zOC0yLjY1Yy42MS0uMjUgMS4xNy0uNTkgMS42OS0uOThsMi40OSAxYy4yMi4wOS40OSAwIC42MS0uMjJsMi0zLjQ2Yy4xMi0uMjIuMDctLjQ5LS4xMi0uNjRsLTIuMTEtMS42NXpNMTIgMTUuNWMtMS45MyAwLTMuNS0xLjU3LTMuNS0zLjVzMS41Ny0zLjUgMy41LTMuNSAzLjUgMS41NyAzLjUgMy41LTEuNTcgMy41LTMuNSAzLjV6Ii8+PC9zdmc+");
        -webkit-mask-repeat: no-repeat;
        mask-repeat: no-repeat;
        background-color:#282828;
        transition: background-color 0.3s ease;
    }
}

.icon-gear:hover
{
    background-color: #0084D6;
}

.header-button:hover .icon-gear 
{
    background-color: #0084D6;
}

.icon-envelope
{
    display: inline-block;
    vertical-align:text-top;
    margin-top:0px;
    margin-right:6px;
    margin-left:-6px;
    width: 24px;
    height: 24px;
    -webkit-mask-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAyNCAyNCI+PHBhdGggZD0iTTIwIDRINC0xLjEgMC0yIC45LTIgMnYxMmMwIDEuMS45IDIgMiAyaDE2YzEuMSAwIDItLjkgMi0yVjZjMC0xLjEtLjktMi0yLTJ6bTAgNGwtOCA1LTgtNVY2bDggNSA4LTV2MnoiLz48L3N2Zz4=");
    mask-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAyNCAyNCI+PHBhdGggZD0iTTIwIDRINC0xLjEgMC0yIC45LTIgMnYxMmMwIDEuMS45IDIgMiAyaDE2YzEuMSAwIDItLjkgMi0yVjZjMC0xLjEtLjktMi0yLTJ6bTAgNGwtOCA1LTgtNVY2bDggNSA4LTV2MnoiLz48L3N2Zz4=");
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    background-color:#282828;
    transition: background-color 0.3s ease;
}
@media screen and (min-width: 768px)
{
    .icon-envelope
    {
        display: inline-block;
        vertical-align:text-top;
        margin-top:0px;
        margin-right:6px;
        margin-left:-6px;
        width: 22px;
        height: 22px;
        -webkit-mask-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAyNCAyNCI+PHBhdGggZD0iTTIwIDRINC0xLjEgMC0yIC45LTIgMnYxMmMwIDEuMS45IDIgMiAyaDE2YzEuMSAwIDItLjkgMi0yVjZjMC0xLjEtLjktMi0yLTJ6bTAgNGwtOCA1LTgtNVY2bDggNSA4LTV2MnoiLz48L3N2Zz4=");
        mask-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAyNCAyNCI+PHBhdGggZD0iTTIwIDRINC0xLjEgMC0yIC45LTIgMnYxMmMwIDEuMS45IDIgMiAyaDE2YzEuMSAwIDItLjkgMi0yVjZjMC0xLjEtLjktMi0yLTJ6bTAgNGwtOCA1LTgtNVY2bDggNSA4LTV2MnoiLz48L3N2Zz4=");
        -webkit-mask-repeat: no-repeat;
        mask-repeat: no-repeat;
        background-color:#282828;
        transition: background-color 0.3s ease;
    }
}

.icon-envelope:hover
{
    background-color: #0084D6;
}

.header-button:hover .icon-envelope 
{
    background-color: #0084D6;
}

#nav-container
{
    display:flex;
}
@media screen and (min-width: 768px)
{
    #nav-container
    {
        display:flex;
        flex-shrink:0;
        flex-wrap:wrap;
        justify-content:center;
        align-items:stretch;
        margin-left:10%;
        margin-right:10%;
        margin-top:20px;
    }
}

#nav-buttons-desktop
{
    display:none;
}
@media screen and (min-width: 768px)
{
    #nav-buttons-desktop
    {
        display:block;
    }
}

#nav-buttons-mobile
{
    display:block;
    padding-left:0px;
    padding-right:0px;
}
@media screen and (min-width: 768px)
{
    #nav-buttons-mobile
    {
        display:none;
    }
}

#nav-menu-button-mobile
{
    display:block;
    margin-top:12px;
    margin-bottom:24px;
    text-align:center;
}
@media screen and (min-width: 768px)
{
    #nav-menu-button-mobile
    {
        display:none;
    }
}

.nav-block
{
    flex:1 0 280px;
    margin-left:10px;
    margin-right:10px;
    margin-bottom:20px;
    padding:20px;
    text-align:center;
    background-color:#FFFFFF;
    border-radius:6px;
    box-shadow: 0 0 4px 2px #F5F5F5;
}

.nav-block-button
{
    display:inline-block;
    width:40%;
    margin-top:8px;
    margin-bottom:8px;
    margin-left:3%;
    margin-right:3%;
    padding:6px;
    font-size:17px;
    text-align:center;
    color:#484848;
    background-color:#FAFAFA;
    box-shadow: 0 0 4px 2px #D9D9D9;
    border-radius:4px;
    user-select:none;
    opacity:.9;
}
@media screen and (min-width: 768px)
{
    .nav-block-button
    {
        display:inline-block;
        width:38%;
        margin-top:8px;
        margin-bottom:8px;
        margin-left:12px;
        margin-right:12px;
        padding:6px;
        font-size:18px;
        text-align:center;
        color:#484848;
        background-color:#F5F5F5;
        box-shadow: 0 0 4px 2px #D9D9D9;
        border-radius:4px;
        user-select:none;
        opacity:.9;
    }
}

.nav-block-button:hover
{
    font-weight:500;
    color:#282828;
    background-color:#EBF7FF;
    box-shadow: 0 0 4px 3px #D9D9D9;
    opacity:95;
}

.nav-block-button-hidden:hover
{
    font-weight:500;
    color:#282828;
    background-color:#F5F5F5;
    box-shadow: 0 0 4px 3px #D9D9D9;
    opacity:95;
}

#nav-block-services
{
    margin-top:20px;
    transition: opacity 0.3s ease-in-out;
    cursor:pointer;
}
@media screen and (min-width: 768px)
{
    #nav-block-services
    {
        margin-top:0px;
        transition: opacity 0.3s ease-in-out;
        cursor:pointer;
    }
}

#nav-block-services-next
{
    display:none;
    margin-top:20px;
    opacity:0;
    transition: opacity 0.3s ease-in-out;
    cursor:pointer;
}
@media screen and (min-width: 768px)
{
    #nav-block-services-next
    {
        display:none;
        opacity:0;
        transition: opacity 0.3s ease-in-out;
        cursor:pointer;
    }
}

.nav-block-background
{
    background-size:cover;
    background-position:90% 50%;
    background-color:rgba(255, 255, 255, 0.85);
    background-blend-mode:lighten;
}
@media screen and (min-width: 768px)
{
    .nav-block-background
    {
        background-size:cover;
        background-position:center;
        background-color:rgba(255, 255, 255, 0.85);
        background-blend-mode:lighten;
    }
}

main
{
    width:100%;
    min-height:90vh;
    margin:0;
    margin-top:10px;
}
@media screen and (min-width: 768px)
{
    main
    {
        flex:1;
        display:flex;
        flex-shrink:0;
        flex-wrap:wrap;
        width:auto;
        min-height:0;
        justify-content:left;
        align-items:flex-start;
        margin-left:10%;
        margin-right:10%;
    }
}

.home-block
{
    flex:0 0 100%;
    box-sizing:border-box;
    max-width:100%;
    margin-left:3%;
    margin-right:3%;
    margin-bottom:20px;
    padding:20px;
    background-color:#FFFFFF;
    border-radius:6px;
    box-shadow: 0 0 4px 2px #F5F5F5;
}
@media screen and (min-width: 768px)
{
    .home-block
    {
        flex:1 0 360px;
        box-sizing:border-box;
        max-width:400px;
        min-height:360px;
        margin-left:10px;
        margin-right:10px;
        margin-bottom:20px;
        padding:20px;
        background-color:#FFFFFF;
        border-radius:6px;
        box-shadow: 0 0 4px 2px #F5F5F5;
    }
}

.home-block-head
{
    font-size:22px;
    font-weight:450;
    margin-bottom:16px;
    padding-bottom:2px;
    border-bottom:1px dotted #B0B0B0;
}

.home-block-text
{
    font-size:16px;
    line-height:26px;
    font-weight:350;
}

.home-block-sub
{
    font-size:17px;
    font-weight:350;
}

.home-service-row
{
    margin-top:40px;
    font-size:21px;
    font-weight:450;
}

#home-block-calendar
{
    transition: opacity 0.4s;
}

#home-block-calendar-content
{
    transition: opacity 0.1s;
}

#home-block-calendar-link
{
    transition: opacity 0.1s;
}

.home-event-row
{
    margin-top:10px;
    margin-bottom:10px;
    font-size:17px;
    text-indent:-16px;
    padding-left:16px;
}

.home-event-row-sub
{
    display:inline;
    font-size:16px;
    color:#484848;
}

.home-event-expand
{
    display:none;
}

.home-event-expand-back
{
    margin-top:-6px;
    font-size:17px;
    color:#0084D6;
    opacity:0.8;
}

.home-event-expand-back a:hover
{
    text-decoration:none;
    font-weight:600;
    opacity:1;
}

.home-event-expand-title
{
    margin-top:16px;
    margin-bottom:16px;
    font-size:22px;
    font-weight:600;
}

.home-event-expand-date
{
    margin-bottom:10px;
    padding-left:8px;
    font-size:16px;
    font-weight:450;
    color:#686868;
    border-left:3px dotted #0084D6;
}
@media screen and (min-width: 768px)
{
    .home-event-expand-date
    {
        margin-bottom:12px;
        padding-left:8px;
        font-size:16px;
        font-weight:450;
        color:#686868;
        border-left:3px dotted #0084D6;
    }
}

.home-event-expand-body
{
    margin-top:24px;
    font-size:17px;
    line-height:25px;
    font-weight:400;
    color:#282828;
}
@media screen and (min-width: 768px)
{
    .home-event-expand-body
    {
        margin-top:30px;
        font-size:17px;
        line-height:25px;
        font-weight:400;
        color:#282828;
    }
}

.home-block-link
{
    margin-top:16px;
    font-size:16px;
    font-weight:400;
}

.home-block-link a
{
    text-decoration:none;
    color:#0084D6;
    opacity:.8;
}

.home-block-link a:hover
{
    text-decoration:underline;
    opacity:.95;
}

.home-livestream-container
{
    width:100%;
    aspect-ratio:3 / 2;
    background-color:#000000;
    border-radius:8px;
}
@media screen and (min-width: 768px)
{
    .home-livestream-container
    {
        width:360px;
        height:240px;
        background-color:#000000;
        border-radius:8px;
    }
}

.home-iframe
{
    border-radius:8px;
    filter:brightness(0.95);
}

.home-block-photo {
    width:100%;
    aspect-ratio:1.36;
    position:relative;
    overflow:hidden;
    border-radius:3px;
    background-color:#000;
    cursor:default;
    transition:transform 0.3s ease-out, box-shadow 0.3s ease-out;
    box-shadow:0 4px 10px rgba(0, 0, 0, 0.2); 
    transform:translateY(0);
    dynamic-range-limit:standard;
}

.home-block-photo:hover
{
    transform:translateY(-2px); 
    box-shadow:0 20px 40px rgba(0, 0, 0, 0.25);
}
@media screen and (min-width: 768px)
{
    .home-block-photo:hover
    {
        transform: scale(1.6) translateY(-5px);
        box-shadow:0 40px 60px rgba(0, 0, 0, 0.75); 
    }
}

.home-block-photo img
{
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:center;
    position:absolute;
    top:0;
    left:0;
    opacity:0;
    transition:opacity 0.8s ease-in-out, transform 8s linear;
    backface-visibility:hidden;
    will-change:transform, opacity;
    transform:scale(1.05) translate(0, 0);
    dynamic-range-limit:standard;
}

.home-block-photo img.active
{
    opacity:0.9;
    z-index:2;
    transform:scale(1.15) translate(-1%, -1%);
}

.home-block-photo:hover img.active
{
    opacity:1;
}

.page-main
{
    width:94%;
    margin-top:10px;
    margin-left:3%;
    margin-right:3%;
    padding-top:20px;
    padding-bottom:20px;
    text-align:left;
    background-color:#FFFFFF;
    border-radius:6px;
    box-shadow: 0 0 4px 2px #F5F5F5;
}
@media screen and (min-width: 768px)
{
    .page-main
    {
        flex:1 0 0;
        margin-left:10%;
        margin-right:10%;
        margin-bottom:20px;
        padding:20px;
        text-align:left;
        background-color:#FFFFFF;
        border-radius:6px;
        box-shadow: 0 0 4px 2px #F5F5F5;
    }
}

.page-head
{
    padding-bottom:10px;
}
@media screen and (min-width: 768px)
{
    .page-head
    {
        display:flex;
        justify-content:space-between;
        align-items:flex-start;
        padding-top:10px;
        padding-bottom:10px;
        padding-left:20px;
        padding-right:60px;
    }
}

.page-content
{
    position:relative;
    margin-top:0px;
    margin-left:6%;
    margin-right:6%;
    padding-bottom:10px;
    font-size:18px;
    line-height:1.5;
}
@media screen and (min-width: 768px)
{
    .page-content
    {
        position:relative;
        margin-top:0px;
        margin-left:40px;
        margin-right:40px;
        padding-bottom:10px;
        font-size:18px;
        line-height:1.5;
    }
}

#page-content-done
{
    display:none;
    position:absolute;
    width:100%;
    margin-top:-32px;
    text-align:center;
    font-size:23px;
    transition:opacity .7s;
    z-index:999;
}

#page-content-done-text
{
    font-size:18px;
    font-weight:500;
    color:#0084D6;
}

#page-content-function
{
    margin-top:10px;
    margin-bottom:20px;
    font-size:15px;
    line-height:22px;
    font-weight:500;
    color:#D22B2B;
}

.notification
{
    display:inline-block;
    padding-top:4px;
    padding-bottom:4px;
    padding-left:20px;
    padding-right:20px;
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border:1px solid rgba(0, 132, 214, 0.2);
    border-radius:100px;
    box-shadow: 
        0 4px 6px -1px rgba(0, 0, 0, 0.05), 
        0 10px 20px -5px rgba(0, 132, 214, 0.15); 
    animation: deepSlideUp 0.6s cubic-bezier(0.23, 1, 0.32, 1) forwards;
}

@keyframes deepSlideUp {
    0% { 
        transform: translateY(80px) scale(0.8); /* Starts much lower and smaller */
        opacity: 0; 
    }
    100% { 
        transform: translateY(0) scale(1); 
        opacity: 1; 
    }
}

.gen-button-gray
{
    display:inline-block;
    padding-top:10px;
    padding-bottom:10px;
    padding-left:20px;
    padding-right:20px;
    font-size:17px;
    text-align:center;
    color:#484848;
    background-color:#F5F5F5;
    box-shadow: 0 0 4px 2px #D9D9D9;
    border-radius:4px;
    user-select:none;
    opacity:.9;
    cursor:pointer;
}

.gen-button-gray:hover
{
    font-weight:500;
    color:#282828;
    background-color:#EBF7FF;
    box-shadow: 0 0 4px 3px #D9D9D9;
    opacity:95;
}

.gen-button-gray-small
{
    display:inline-block;
    padding-top:6px;
    padding-bottom:6px;
    padding-left:12px;
    padding-right:12px;
    font-size:15px;
    text-align:center;
    color:#484848;
    background-color:#F5F5F5;
    box-shadow: 0 0 4px 2px #D9D9D9;
    border-radius:4px;
    user-select:none;
    opacity:.9;
    cursor:pointer;
}

.gen-button-gray-small:hover
{
    font-weight:500;
    color:#282828;
    background-color:#EBF7FF;
    box-shadow: 0 0 4px 3px #D9D9D9;
    opacity:95;
}

.gen-button-blue
{
    display: inline-block;
    padding: 10px 20px;
    font-size: 17px;
    font-weight: 500;
    text-align: center;
    color: #444;
    background-color: #F8F9FA;
    border: 1px solid #E0E0E0;
    border-bottom: 2px dotted #0084D6; 
    border-radius: 4px;
    user-select: none;
    cursor: pointer;
    transition: all 0.2s ease;
}

.gen-button-blue:hover
{
    background-color: #FFFFFF;
    color: #0084D6;
    border: 1px solid #0084D6;
    border-bottom: 2px solid #0084D6;
    box-shadow: 0 2px 8px rgba(0, 132, 214, 0.15);
}

.gen-button-blue:active
{
    transform: translateY(1px);
    box-shadow: 0 2px 4px rgba(0, 132, 214, 0.1);
}

.gen-button-blue-active
{
    display: inline-block;
    padding: 10px 20px;
    font-size: 17px;
    font-weight: 500;
    text-align: center;
    background-color: #FFFFFF;
    color: #0084D6;
    border: 1px solid #0084D6;
    border-bottom: 2px solid #0084D6;
    box-shadow: 0 2px 8px rgba(0, 132, 214, 0.15);
    border-radius: 4px;
    user-select: none;
    cursor: pointer;
    transition: all 0.2s ease;
}

.header-button
{
    position:relative;
    display:inline-block;
    margin-top:6px;
    margin-bottom:6px;
    margin-left:10px;
    margin-right:10px;
    padding-top:6px;
    padding-bottom:6px;
    padding-left:20px;
    padding-right:20px;
    font-size:17px;
    font-weight:500;
    text-align:center;
    color:#444;
    background-color:#FDFEFF;
    border:1px solid #C0C0C0;
    border-radius:4px;
    user-select:none;
    cursor:pointer;
    transition:all 0.2s ease;
}
@media screen and (min-width: 768px)
{
    .header-button
    {
        display:inline-block;
        margin-top:6px;
        margin-bottom:6px;
        margin-left:0px;
        margin-right:0px;
        padding-top:5px;
        padding-bottom:5px;
        padding-left:20px;
        padding-right:20px;
        font-size:16px;
        font-weight:500;
        text-align:center;
        color:#444;
        background-color:#FDFEFF;
        border:1px solid #C0C0C0;
        border-radius:4px;
        user-select:none;
        cursor:pointer;
        transition:all 0.2s ease;
    }
}

.header-button:hover
{
    background-color: #FFFFFF;
    color: #0084D6;
    border: 1px solid #0084D6;
    box-shadow: 0 2px 8px rgba(0, 132, 214, 0.15);
    text-decoration:none;
}

.header-button:active
{
    transform: translateY(1px);
    box-shadow: 0 2px 4px rgba(0, 132, 214, 0.1);
}

.page-content-button
{
    width:110px;
    margin-left:20px;
    margin-right:20px;
}
@media screen and (min-width: 768px)
{
    .page-content-button
    {
        width:110px;
        margin-left:20px;
        margin-right:20px;
    }
}

.admin-menu-button
{
    position:relative;
    width:160px;
    margin-bottom:35px;
    margin-left:15px;
    margin-right:15px;
    padding-top:15px;
    padding-bottom:15px;
    font-size:18px;
    font-weight:500;
}

.admin-menu-button:hover
{
}

#page-nav-home-desktop
{
    display:none;
}
@media screen and (min-width: 768px)
{
    #page-nav-home-desktop
    {
        display:block;
        width:100%;
        margin-top:0px;
    }
}

a:has(.nav-block-button)
{
    text-decoration: none !important;
}

a:has(.header-button)
{
    text-decoration: none !important;
}

#page-nav-home-mobile
{
    display:block;
    width:100%;
    text-align:center;
    margin-top:0px;
    margin-bottom:20px;
}
@media screen and (min-width: 768px)
{
    #page-nav-home-mobile
    {
        display:none;
    }
}

#page-content-head
{
    width:90%;
    max-width:900px;
    margin:0 auto;
    padding-left:10px;
}

#page-content-head-text
{
    font-size:24px;
    font-weight:600;
}

#page-content-head-edit, .page-content-head-edit
{
    font-size:14px;
    font-weight:300;
    opacity:0.8;
}

.page-news-expand-body
{
    width:90%;
    margin-top:0px;
    margin-bottom:20px;
    margin-left:18px;
    padding-left:10px;
    padding-top:4px;
    font-size:17px;
    line-height:25px;
    font-weight:400;
    color:#282828;
    border-left:3px dotted #0084D6;
}
@media screen and (min-width: 768px)
{
    .page-news-expand-body
    {
        width:80%;
        margin-top:0px;
        margin-bottom:20px;
        margin-left:18px;
        padding-left:10px;
        padding-top:4px;
        font-size:17px;
        line-height:25px;
        font-weight:400;
        color:#282828;
        border-left:3px dotted #0084D6;
    }
}

.page-news-expand 
{
    height: 0;
    opacity: 0;
    overflow: hidden;
    transition: height 0.4s cubic-bezier(0.25, 0.1, 0.25, 1), opacity 0.2s ease-in;
}

.page-news-expand.active 
{
    opacity: 1;
}

.page-news-row-sub
{
    display:block;
    margin-top:4px;
    text-indent:0px;
}
@media screen and (min-width: 768px)
{
    .page-news-row-sub
    {
        display:unset;
        margin-top:unset;
        text-indent:unset;
    }
}

#page-events-head
{
    font-size:24px;
    font-weight:600;
}

.page-events-row
{
    margin-top:10px;
    margin-bottom:10px;
    font-size:17px;
}

.event-date-box
{
    display:inline-block;
    vertical-align:top;
    width:46px;
    margin-right:20px;
    margin-top:10px;
    margin-bottom:10px;
    border:2px solid #D9D9D9;
    border-radius:8px;
    overflow:hidden;
    font-family:sans-serif;
    background-color:#FFFFFF;
    text-indent:0;
    box-shadow:0 1px 4px rgba(219,82,82,0.2);
    user-select:none;
    position: relative;
    z-index: 2;
}

.day-name
{
    background-color:#F9F2F2;
    color:#000000;
    width:100%;
    text-align:center;
    font-size:13px;
    font-weight:600;
    padding:4px 0;
    text-transform:uppercase;
    margin:0;
    border-bottom:2px solid #DB5252;
    box-sizing:border-box;
}

.day-number
{
    width:100%;
    text-align:center;
    font-size:20px;
    font-weight:800;
    color:#333;
    padding:5px 0;
    margin:0;
    line-height:18px;
}

.page-events-date-lines
{
    display:inline-block;
    margin-top:20px;
    margin-left:-50px;
    padding-left:50px;
    border-left:1px dotted #DB5252;
    width:75%;
}

.page-events-expand
{
    height: 0;
    opacity: 0;
    overflow: hidden;
    margin-bottom: 0;
    padding-left:12px;
    border-left:2px dotted #0084D6;
    transition: height 0.4s cubic-bezier(0.25, 0.1, 0.25, 1), 
                opacity 0.2s ease-in, 
                margin-bottom 0.4s;
}

.page-events-expand.active
{
    opacity: 1;
}

#page-events-none
{
    margin-top:40px;
}

.page-events-pick-month
{
    display:inline-block;
    margin-bottom:20px;
    font-size:16px;
    opacity:.8;
}

.page-events-pick-month-right
{
    position:absolute;
    right:0;
}

.bulletin-object
{
}
@media screen and (min-width: 768px)
{
    .bulletin-object
    {
        min-width:60%;
        max-width:700px;
        aspect-ratio: 8.5 / 11;
        border:1px solid #C0C0C0;
        border-radius:4px;
        box-shadow:0 4px 15px rgba(0, 0, 0, 0.1);
        background-color:#FFFFFF;
    }
}

.page-bulletin-title
{
    margin-bottom:4px;
    font-size:19px;
    font-size:500;
}

.page-bulletin-sub
{
    margin-bottom:10px;
    font-size:15px;
    font-weight:350;
    color:#808080;
}

.page-para
{
    margin-top:10px;
    margin-bottom:10px;
}
@media screen and (min-width: 768px)
{
    .page-para
    {
        margin-top:10px;
        margin-bottom:10px;
    }
}

.page-para-narrow
{
    margin-top:20px;
    margin-bottom:20px;
    margin-left:2%;
    margin-right:2%;
}
@media screen and (min-width: 768px)
{
    .page-para-narrow
    {
        margin-top:20px;
        margin-bottom:20px;
        margin-left:23%;
        margin-right:23%;
    }
}

.page-note
{
    font-size:14px;
    font-weight:350;
    color:#808080;
}

.page-note a
{
    color:#808080;
}

.page-prayers-text
{
    font-size:16px;
    color:#484848;
}

.page-prayers-anon-tabs
{
    display:block;
    margin-left:0px;
    margin-top:10px;
}
@media screen and (min-width: 768px)
{
    .page-prayers-anon-tabs
    {
        display:inline-block;
        margin-left:20px;
        margin-top:0px;
    }
}

.tab-button
{
    display:inline-block;
    padding-top:10px;
    padding-bottom:10px;
    margin-left:1px;
    margin-right:1px;
    font-size:17px;
    text-align:center;
    color:#484848;
    background-color:#F5F5F5;
    box-shadow: 0 0 4px 2px #D9D9D9;
    user-select:none;
    opacity:.9;
    cursor:pointer;
}

.tab-button:hover
{
    color:#282828;
    box-shadow: 0 0 4px 3px #D9D9D9;
}

.tab-button-small
{
    display:inline-block;
    padding-top:5px;
    padding-bottom:5px;
    margin-left:1px;
    margin-right:1px;
    font-size:15px;
    text-align:center;
    color:#484848;
    background-color:#F5F5F5;
    box-shadow: 0 0 4px 2px #D9D9D9;
    user-select:none;
    opacity:.9;
    cursor:pointer;
}

.tab-button-small:hover
{
    color:#282828;
    box-shadow: 0 0 4px 3px #D9D9D9;
}

.tab-button-small-blue:hover
{
    font-weight:500;
    color:#282828;
    background-color:#EBF7FF;
    box-shadow: 0 0 4px 3px #D9D9D9;
    opacity:95;
}

.tab-button-active
{
    font-weight:500;
    color:#282828;
    background-color:#EBF7FF;
    box-shadow: 0 0 4px 3px #D9D9D9;
    opacity:95;
}

.rental-new-space-button
{
    display:inline-block;
    padding-top:8px;
    padding-bottom:8px;
    padding-left:12px;
    padding-right:12px;
    margin-top:20px;
    margin-left:20px;
    margin-right:20px;
    font-size:16px;
    text-align:center;
    color:#484848;
    background-color:#F5F5F5;
    box-shadow: 0 0 4px 2px #D9D9D9;
    user-select:none;
    opacity:.9;
    cursor:pointer;
}

.rental-new-space-button:hover
{
    color:#282828;
    box-shadow: 0 0 4px 3px #D9D9D9;
}

.rental-new-space-button-selected
{
    font-weight:500;
    color:#282828;
    background-color:#EBF7FF;
    box-shadow: 0 0 4px 3px #D9D9D9;
    opacity:95;
    cursor:pointer;
}

.page-rental-img img
{
    max-width:50%;
}
@media screen and (min-width: 768px)
{
    .page-rental-img img
    {
        max-width:25%;
    }
}

.grid-table
{
    display: grid;
    grid-template-columns: 1fr;
    width: 100%;
    border-top: 1px solid #eee;
}

.grid-header
{
    display: none;
}

.grid-cell
{
    padding: 10px 15px;
    border-bottom: 1px solid #eee;
    display: flex;
    justify-content: space-between;
    align-items: center;
    text-align: right;
}

.grid-cell::before
{
    content: attr(data-label);
    font-weight: bold;
    color: #666;
    text-align: left;
    padding-right: 10px;
}

.grid-cell:nth-of-type(5n)
{
    border-bottom: 4px solid #ddd; 
    margin-bottom: 10px;
}

@media screen and (min-width: 768px)
{
    .grid-table
    {
        grid-template-columns: 2fr 2fr 1.5fr 1.5fr 1fr 1fr;
        border: 1px solid #D9D9D9;
        border-radius:4px;
    }

    .grid-cell
    {
        display: block;
        text-align: left;
        font-size:15px;
        border-bottom: 1px solid #eee;
    }

    .grid-cell::before
    {
        display: none;
    }
    
    .grid-header
    {
        display: block;
        font-size:17px;
        font-weight: 600;
        background-color: #F5F5F5;
        text-align: left;
        cursor:pointer;
    }

    .grid-cell:nth-of-type(5n)
    {
        border-bottom: 1px solid #eee;
        margin-bottom: 0;
    }
}

.grid-row:hover
{
    background-color:#EBF7FF;
}

#message-list
{
    display:inline-block;
    text-align:left;
    width:100%;
}
@media screen and (min-width: 768px)
{
    #message-list
    {
        display:inline-block;
        text-align:right;
        width:70%;
        max-width:600px;
        margin-left:-15%;
    }
}

.message-list-row
{
    display:inline-block;
    width:80%;
    margin-top:10px;
    margin-bottom:10px;
    text-align:left;
    padding:15px;
    font-size:17px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
    border-radius:4px;
    opacity:0.9;
    cursor:pointer;
}
@media screen and (min-width: 768px)
{
    .message-list-row
    {
        display:inline-block;
        width:80%;
        max-width:550px;
        margin-top:10px;
        margin-bottom:10px;
        text-align:left;
        padding:15px;
        font-size:17px;
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
        border-radius:4px;
        opacity:0.9;
        cursor:pointer;
    }
}

.message-list-row:hover
{
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
    opacity:1;
}

.message-row-list-sub
{
    font-size:16px;
    color:#484848;
}

.message-list-unread
{
    display:inline-block;
    vertical-align:top;
    width:12px;
    height:12px;
    margin-top:32px;
    margin-right:15px;
    border-radius:50%;
    background-color:#0084D6;
    opacity:0.8;
}

.message-list-unread-hide
{
    opacity:0;
}

.message-list-expand
{
    display:none;
    width:90%;
    margin-top:10px;
    margin-bottom:10px;
    margin-left:2px;
    padding-left:10px;
    padding-top:1px;
    padding-bottom:1px;
    font-size:17px;
    line-height:25px;
    font-weight:400;
    color:#282828;
    border-left:3px dotted #0084D6;
    cursor:text;
}
@media screen and (min-width: 768px)
{
    .message-list-expand
    {
        display:none;
        width:90%;
        margin-top:10px;
        margin-bottom:10px;
        margin-left:2px;
        padding-left:10px;
        padding-top:1px;
        padding-bottom:1px;
        font-size:17px;
        line-height:25px;
        font-weight:400;
        color:#282828;
        border-left:3px dotted #0084D6;
        cursor:text;
    }
}

.message-expand-thread
{
    margin-top:0px;
    margin-bottom:0px;
}

.message-expand-thread-item
{
    margin-bottom:0px;
    padding-top:20px;
    padding-bottom:10px;
    border-top:1px dashed #C0C0C0;
}

.gen-message-button
{
    display:inline-block;
    margin-top:10px;
    padding-top:6px;
    padding-bottom:6px;
    padding-left:12px;
    padding-right:12px;
    font-size:16px;
    text-align:center;
    color:#444;
    background-color:#F8F9FA;
    border:1px solid #C0C0C0;
    border-radius:4px;
    user-select:none;
    cursor:pointer;
    transition:all 0.2s ease;
    opacity:.7;
}

.gen-message-button:hover
{
    background-color: #FFFFFF;
    color: #0084D6;
    border: 1px solid #0084D6;
    box-shadow: 0 2px 8px rgba(0, 132, 214, 0.15);
    text-decoration:none;
}

.gen-message-button:active
{
    transform: translateY(1px);
    box-shadow: 0 2px 4px rgba(0, 132, 214, 0.1);
}

.mail-block
{
    margin-top:10px;
    margin-bottom:10px;
    text-align:left;
    font-size:18px;
    font-weight:400;
    color:#282828;
    white-space:pre-wrap;
    word-break:break-word;
}
@media screen and (min-width: 768px)
{
    .mail-block
    {
        margin-top:10px;
        margin-bottom:10px;
        text-align:left;
        font-size:18px;
        font-weight:400;
        color:#282828;
        white-space:pre-wrap;
        word-break:break-word;
    }
}

.mail-block a
{
    color:#0084D6;
    font-weight:500;
}

.mail-block strong,
.mail-block[style*="font-weight:bold"],
.mail-block[style*="font-weight: bold"],
.mail-block[style*="font-weight:700"],
.mail-block[style*="font-weight: 700"] {
  font-weight: 500 !important;
}

.message-body-button
{
    display:none;
}

.message-expand-buttons
{
    display:none;
    margin-left:0px;
    text-align:center;
}
@media screen and (min-width: 768px)
{
    .message-expand-buttons
    {
        display:none;
        text-align:left;
        margin-left:10px;
    }
}

#message-nav
{
    display:none;
}
@media screen and (min-width: 768px)
{
    #message-nav
    {
        position:absolute;
        right:0;
        display:inline-block;
        vertical-align:top;
        text-align:right;
    }
}

#message-nav-mobile
{
    display:block;
    position:relative;
    margin-top:40px;
}
@media screen and (min-width: 768px)
{
    #message-nav-mobile
    {
        display:none;
    }
}

#message-settings
{
    display:none;
    text-align:left;
    width:70%;
    max-width:600px;
    margin-left:0%;
}

#message-compose
{
    display:none;
    text-align:left;
    width:100%;
    margin-left:0%;
}
@media screen and (min-width: 768px)
{
    #message-compose
    {
        display:none;
        text-align:left;
        width:70%;
        max-width:600px;
        margin-left:0%;
    }
}

.message-button-margin
{
    margin-left:10px;
    margin-right:10px;
}
@media screen and (min-width: 768px)
{
    .message-button-margin
    {
        margin-left:30px;
        margin-right:0px;
    }
}

.header-message-unread
{
    position:absolute;
    left:-20px;
    top:8px;
    width:12px;
    height:12px;
    border-radius:50%;
    background-color:#0084D6;
    opacity:0.8;
}

.header-right-mobile
.header-message-unread
{
    top:14px;
    left:-26px;
    width:16px;
    height:16px;
}

.admin-alert-count
{
    position:absolute;
    min-width:14px;
    left:-14px;
    top:-10px;
    padding-top:2px;
    padding-bottom:2px;
    padding-left:6px;
    padding-right:6px;
    font-size:15px;
    font-weight:500;
    border-radius:50%;
    color:#FFFFFF;
    background-color:#0084D6;
    opacity:0.9;
}

.page-giving-block
{
    flex: 1;
    padding:20px;
    border-radius:4px;
    background-color:#F7F7F7;
}

.currency-container
{
    display:inline-flex;
    align-items:center;
    background-color:#FFFFFF;
    border:1px solid #CCCCCC;
    border-radius:4px;
    padding-left:8px;
    margin-left:10px;
}

.currency-symbol
{
    font-size:20px;
    color:#555555;
    font-weight:bold;
    user-select:none;
}

.currency-container .gen-input
{
    border:none !important;
    outline:none !important;
    padding-left:4px;
    background:transparent;
}

.currency-container .gen-input::-webkit-outer-spin-button,
.currency-container .gen-input::-webkit-inner-spin-button
{
    -webkit-appearance:inner-spin-button;
    opacity:1;
}

.currency-container .gen-input
{
    -moz-appearance:number-input;
    border:none !important;
    outline:none !important;
    padding-left:4px;
    background:transparent;
}

.giving-recurring-block
{
    margin-left:auto;
    margin-right:auto;
    margin-top:-15px;
    margin-bottom:30px;
    padding-top:20px;
    border:2px dotted #2196F3;
    border-radius:6px;
}
@media screen and (min-width: 768px)
{
    .giving-recurring-block
    {
        width:350px;
        margin-left:auto;
        margin-right:auto;
        margin-top:-15px;
        margin-bottom:30px;
        padding-top:20px;
        border:2px dotted #2196F3;
        border-radius:6px;
    }
}

.homepage-hover:hover
{
    box-shadow:0px 0px 3px 1px #D9D9D9;
}

.edit-block
{
  position:relative;
  padding:20px;
}

.edit-block-controls
{
  display: none;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.65);
  z-index: 10;
  border-radius:6px;
  text-align:center;
}

.nav-block:hover .edit-block-controls
{
  display: block;
}

.home-block:hover .edit-block-controls
{
  display: block;
}

.photo-thumb-wrap:hover .photo-thumb-delete
{
    display:block !important;
}

.photo-thumb-img
{
    box-shadow: rgba(0, 0, 0, 0.2) 0px 4px 10px;
}

.photo-thumb-img:hover
{
    box-shadow: rgba(0, 0, 0, 0.4) 0px 4px 10px;
}

.grid-cell-clickable
{
    cursor: pointer;
}

.grid-cell-clickable:hover
{
    background-color: #F5F5F5;
}

.grid-expand
{
    padding: 20px;
    border-bottom: 1px solid #E0E0E0;
    background-color: #FAFAFA;
}

/* ===== PUBLIC HERO ===== */

#public-memberships
{
    text-align:center;
    padding:5px 20px 20px 20px;
}

.public-memberships-head
{
    font-size:20px;
    font-weight:600;
    color:#282828;
    margin-bottom:8px;
}

#public-hero
{
    text-align:center;
    padding:50px 20px 40px 20px;
    background:linear-gradient(135deg, #FAFAFF 0%, #EEF4FF 100%);
    border-bottom:1px solid #E0E8FF;
}

.public-hero-head
{
    font-size:32px;
    font-weight:600;
    color:#282828;
    margin-bottom:12px;
}

@media screen and (min-width:768px)
{
    .public-hero-head
    {
        font-size:46px;
    }
}

.public-hero-sub
{
    font-size:16px;
    color:#606060;
    margin-bottom:32px;
    max-width:500px;
    margin-left:auto;
    margin-right:auto;
    line-height:1.6;
}

/* ===== SEARCH BOX ===== */

#public-search-box
{
    display:inline-block;
    background:#FFFFFF;
    border:2px solid #D0D8FF;
    border-radius:12px;
    padding:24px;
    width:100%;
    max-width:520px;
    box-shadow:0 4px 20px rgba(0,132,214,0.08);
    text-align:left;
    box-sizing:border-box;
    margin-left:auto;
    margin-right:auto;
}

#search-tabs
{
    display:flex;
    gap:8px;
    margin-bottom:24px;
}

.search-tab
{
    flex:1;
    padding:8px;
    text-align:center;
    border-radius:6px;
    font-size:14px;
    cursor:pointer;
    border:1px solid #D0D8FF;
    color:#606060;
    user-select:none;
    transition:all 0.15s;
}

.search-tab.active
{
    background:#0084D6;
    color:#FFFFFF;
    border-color:#0084D6;
}

.search-panel
{
    display:none;
}

.search-panel.active
{
    display:block;
    margin-bottom:20px;
}

/* ===== SEARCH INPUTS ===== */

#public-search-box select.gen-input
{
    font-size:17px;
    padding:12px 14px;
    height:auto;
    max-width:300px;
    margin-bottom:8px;
}

/* ===== RESULTS ===== */

#public-results
{
    max-width:680px;
    margin:40px auto;
    padding:0 20px;
}

.public-results-count
{
    font-size:14px;
    color:#808080;
    margin-bottom:16px;
    text-align:center;
}

.church-card
{
    background:#FFFFFF;
    border:1px solid #E8EEF8;
    border-radius:10px;
    padding:18px 20px;
    margin-bottom:12px;
    box-shadow:0 2px 8px rgba(0,0,0,0.04);
    position:relative;
}

.church-card-name
{
    font-size:17px;
    font-weight:600;
    color:#282828;
    margin-bottom:6px;
    padding-right:36px;
}

.church-card-detail
{
    font-size:14px;
    color:#606060;
    margin-bottom:3px;
}

.church-card-distance
{
    font-size:13px;
    color:#0084D6;
    font-weight:500;
    margin-top:8px;
}

.church-card-tcc
{
    position:absolute;
    top:14px;
    right:14px;
}

.church-card-tcc img
{
    height:36px;
    opacity:0.85;
}

/* ===== WALL ===== */

.public-wall
{
    text-align:center;
    padding:30px 24px;
    background:#F0F6FF;
    border:1px dashed #0084D6;
    border-radius:10px;
    margin-top:8px;
}

.public-wall-head
{
    font-size:20px;
    font-weight:600;
    color:#282828;
    margin-bottom:8px;
}

.public-wall-sub
{
    font-size:14px;
    color:#606060;
    margin-bottom:16px;
}

#preview-bar {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    background-color: #0084D6;
    color: #fff;
    text-align: center;
    padding: 15px 20px;
    font-size: 18px;
    font-family: Lora;
    z-index: 9999;
    box-sizing: border-box;
}

#preview-bar a {
    color: #fff;
    text-decoration: underline;
}

.preview-block {
    position: relative;
}

.preview-block-overlay {
    display: none;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.65);
    z-index: 10;
    border-radius: 6px;
    text-align: center;
    color: #fff;
    font-size: 16px;
    padding: 20px;
    box-sizing: border-box;
    align-items: center;
    justify-content: center;
}

.preview-block:hover .preview-block-overlay {
    display: flex;
}

.preview-tooltip {
    display: none;
    position: absolute;
    top: 40px;
    right: 0;
    width: 220px;
    background: rgba(0, 0, 0, 0.80);
    color: #fff;
    font-size: 13px;
    padding: 10px 12px;
    border-radius: 6px;
    z-index: 9999;
    line-height: 1.4;
    text-align: center;
}

.preview-tooltip:hover,
div:hover > .preview-tooltip {
    display: block;
}