/* ==========================================================================
   Utility Classes
   ========================================================================== */

/* --- Buttons --- */

.button,
button,
input[type="button"],
input[type="reset"],
input[type="submit"] {
  background-color: transparent;
    display: inline-block;
    border-radius: var(--radius-lg);
    color: var(--color-white);
    cursor: pointer;
    font-size: 1.125rem;
    font-weight: var(--font-weight-semibold);
    padding: 0.75rem 1.5625rem;
    text-align: center;
    text-decoration: none;
    white-space: normal;
    width: auto;
    line-height: 1.4;
    transition: all var(--transition-fast);
}

input[type="button"]:focus,
input[type="submit"]:focus {
    background-color: var(--color-accent-hover);
    color: var(--color-white);
}

.button:focus-visible,
button:focus-visible,
input[type="submit"]:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

.entry-content .button:focus,
.entry-content .button:hover {
    color: var(--color-white);
}

.button--large {
    font-size: 1.125rem;
    padding: 0.75rem 1.5625rem;
}

@media (any-hover: hover) {
    .button--large:hover {
        color: var(--color-secondary) !important;
        background: var(--color-white) !important;
    }
}

.site-container div.wpforms-container-full .wpforms-form input[type="submit"],
.site-container div.wpforms-container-full .wpforms-form button[type="submit"] {
    border: 0;
    border-radius: var(--radius-lg);
    color: var(--color-white);
    cursor: pointer;
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    padding: 0.75rem 1.5625rem;
    text-decoration: none;
    transition: all var(--transition-fast);
}

@media (any-hover: hover) {
    .site-container div.wpforms-container-full .wpforms-form input[type="submit"]:hover,
    .site-container div.wpforms-container-full .wpforms-form button[type="submit"]:hover {
        background-color: var(--color-accent-hover);
        color: var(--color-white);
    }
}

.site-container button:disabled,
.site-container button:disabled:hover,
.site-container input:disabled,
.site-container input:disabled:hover,
.site-container input[type="button"]:disabled,
.site-container input[type="button"]:disabled:hover,
.site-container input[type="reset"]:disabled,
.site-container input[type="reset"]:disabled:hover,
.site-container input[type="submit"]:disabled,
.site-container input[type="submit"]:disabled:hover {
    background-color: var(--color-border);
    border-width: 0;
    color: var(--color-text-muted);
    cursor: not-allowed;
}

.button--sm {
    padding: 0.5rem 1rem;
    font-size: var(--font-size-sm);
}

.button--lg {
    padding: 1rem 2.5rem;
    font-size: var(--font-size-lg);
}

.button--white {
    background-color: var(--color-white);
    color: var(--color-accent);
}

@media (any-hover: hover) {
    .button--white:hover {
        background-color: var(--color-white) !important;
        color: var(--color-secondary) !important;
    }
}

.button--outline {
    background-color: transparent;
    border: 2px solid currentColor;
}

/* --- Top Bar / Announcement Bar --- */

#before-body {
    min-height: 35px;
    background-image: var(--gradient-brand);
}

#before-body.announcement-bar--has-content {
    height: auto;
    padding: var(--spacing-sm) var(--spacing-md);
    text-align: center;
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    color: var(--color-white);
    line-height: 1.4;
}

#before-body.announcement-bar--has-content a {
    color: inherit;
    text-decoration: underline;
}

@media (any-hover: hover) {
    #before-body.announcement-bar--has-content a:hover {
        opacity: 0.85;
    }
}

.announcement-bar__container {
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--container-padding);
}

#before-body.announcement-bar--has-content p {
    margin: 0;
}

/* --- Site Container --- */

.site-container {
    animation: cbtm-fadein 0.6s ease-out;
    word-wrap: break-word;
}

@keyframes cbtm-fadein {
    from { opacity: 0; }
    to { opacity: 1; }
}


/* --- Card Styles --- */

.pop-card {
    background: var(--color-white);
    overflow: hidden;
    border-radius: var(--radius-lg);
    box-shadow: 0 0 16px -3px rgba(0, 0, 0, 0.57);
}

.sunk-card {
    background: var(--color-bg);
    overflow: hidden;
    border-radius: var(--radius-lg);
}

/* --- Custom Accordion --- */

.custom-accordion {
    font-family: var(--font-quicksand);
    font-weight: var(--font-weight-black);
    color: var(--color-secondary);
    font-size: 1.25rem;
}

/* --- Introductory Block --- */

.introductory-block-title {
    font-family: var(--font-quicksand);
    font-weight: var(--font-weight-black);
}

.introductory-block-content {
    font-family: var(--font-opensans);
    font-weight: var(--font-weight-medium);
    font-style: normal;
}

/* --- Visibility --- */

.hidden {
    display: none !important;
}

.visually-hidden {
    border: 0;
    clip: rect(0, 0, 0, 0);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
}

/* --- Image Utilities --- */

.ibg {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.ibg--contain {
    object-fit: contain;
}

/* --- WordPress Alignments --- */

.alignleft {
    float: left;
    margin-right: var(--spacing-lg);
    margin-bottom: var(--spacing-md);
}

.alignright {
    float: right;
    margin-left: var(--spacing-lg);
    margin-bottom: var(--spacing-md);
}

.aligncenter {
    display: block;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: var(--spacing-md);
}

.alignnone {
    margin-bottom: var(--spacing-md);
}

.alignfull {
    width: 100%;
    max-width: 100%;
    margin-left: 0;
    margin-right: 0;
}

.alignwide {
    max-width: var(--container-wide);
    margin-left: auto;
    margin-right: auto;
}

/* --- WordPress Captions --- */

.wp-caption {
    max-width: 100%;
    margin-bottom: var(--spacing-md);
}

.wp-caption img {
    display: block;
    max-width: 100%;
    height: auto;
}

.wp-caption-text,
figcaption {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
    margin-top: var(--spacing-xs);
    text-align: center;
}

/* --- Text Utilities --- */

.text-center {
    text-align: center;
}

.text-left {
    text-align: left;
}

.text-right {
    text-align: right;
}

/* --- Clearfix --- */

.clearfix::after {
    content: "";
    display: table;
    clear: both;
}

/* --- Skip Links --- */

.skip-link {
    background-color: var(--color-bg-white);
    color: var(--color-primary);
    font-weight: var(--font-weight-bold);
    padding: var(--spacing-sm) var(--spacing-md);
    position: absolute;
    top: -100%;
    left: 0;
    z-index: var(--z-toast);
    transition: top var(--transition-fast);
}

.skip-link:focus {
    top: 0;
}

/* --- WPML Compatibility --- */

@media (min-width: 960px) {
.wpml-ls-item-en {
        margin-left: 15px;
    }
}
