/* SCMS Starter — Default Styles */

/* ── Global ──────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
img { max-width: 100%; height: auto; display: block; }
.embed-container { position: relative; padding-bottom: 56.25%; height: 0; overflow: hidden; }
.embed-container iframe, .embed-container video { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }

/* ── Buttons ─────────────────────────────────────────────── */
.button, a.button, button.button {
    display:          inline-block;
    background:       var(--btn-bg);
    color:            var(--btn-text);
    padding:          var(--btn-padding);
    font-size:        var(--btn-font-size);
    font-family:      var(--font-primary);
    border-radius:    var(--btn-radius);
    border:           none;
    text-decoration:  none;
    cursor:           pointer;
    transition:       background var(--transition-base), color var(--transition-base);
    line-height:      1.4;
}
.button:hover, a.button:hover { background: var(--btn-bg-hover); color: var(--btn-text); text-decoration: none; }

/* ── Site Layout ─────────────────────────────────────────── */
.site-header { background: var(--header-bg); }
.site-footer { background: var(--footer-bg); color: var(--footer-text); }
.site-footer a { color: var(--footer-link); }
.page-content { padding: var(--space-xl) 0; }

/* ── Page Banner ─────────────────────────────────────────── */
.pageBanner {
    position:    relative;
    min-height:  var(--banner-min-height);
    display:     flex;
    align-items: center;
    overflow:    hidden;
    background:  var(--color-primary);
}
.pageBanner.hasBannerImage::after {
    content:     '';
    position:    absolute;
    inset:       0;
    background:  rgba(0,0,0,var(--banner-overlay-opacity));
}
.bannerImage { position: absolute; inset: 0; }
.bannerImage img { width: 100%; height: 100%; object-fit: cover; }
.bannerContent { position: relative; z-index: 2; }
.bannerTitle { color: var(--banner-text-color); margin: 0; }

/* ── dynamicContent wrapper ──────────────────────────────── */
.dynamicContent { padding: var(--space-xl) 0; }

/* ── Staff ───────────────────────────────────────────────── */
.staffMember, .staffContent { margin-bottom: var(--space-lg); }
.staff-meta { margin-bottom: var(--space-sm); }
.meta-label { font-weight: 700; }
.email-value { word-break: break-all; }

/* ── POI ─────────────────────────────────────────────────── */
.poi { display: block; position: relative; overflow: hidden; text-decoration: none; border-radius: var(--border-radius-md); }
.poiImage { position: relative; }
.poiImageBG img { width: 100%; height: 220px; object-fit: cover; display: block; }
.poiText { position: absolute; bottom: 0; left: 0; right: 0; padding: var(--space-md); background: linear-gradient(transparent, rgba(0,0,0,0.7)); color: var(--color-white); }
.poiTitle { font-weight: 700; font-size: var(--text-lg); }
.poiEx { font-size: var(--text-sm); margin-top: var(--space-xs); }
.textOnlyBlock { background: var(--color-primary); padding: var(--space-lg); color: var(--color-white); border-radius: var(--border-radius-md); }

/* ── Callout ─────────────────────────────────────────────── */
.callout { position: relative; overflow: hidden; padding: var(--space-3xl) 0; }
.callout.hasbg::after { content: ''; position: absolute; inset: 0; background: rgba(0,0,0,0.5); }
.coimg { position: absolute; inset: 0; }
.coimg picture, .coimg img { width: 100%; height: 100%; object-fit: cover; }
.calloutContent { position: relative; z-index: 2; color: var(--color-white); }
.callout:not(.hasbg) .calloutContent { color: var(--color-text); }
.calloutTitle h3 { color: inherit; }

/* ── Documents ───────────────────────────────────────────── */
.documents { padding: var(--space-md) 0; }
.document-link { margin-bottom: var(--space-sm); width: 100%; text-align: left; }

/* ── FAQ ─────────────────────────────────────────────────── */
.accordionGroup { border-top: 1px solid var(--color-mid-grey); }
.accordionItem { border-bottom: 1px solid var(--color-mid-grey); }
.accordionTab { padding: var(--space-md) 0; margin: 0; cursor: pointer; position: relative; font-size: var(--text-md); }
.accordionTab::after { content: '+'; position: absolute; right: 0; font-size: var(--text-xl); line-height: 1; transition: transform var(--transition-base); }
.accordionItem.open .accordionTab::after { transform: rotate(45deg); }
.accordionContent { display: none; padding-bottom: var(--space-md); }
.accordionItem.open .accordionContent { display: block; }

/* ── Quotes ──────────────────────────────────────────────── */
.quotes-holder { text-align: center; padding: var(--space-xl) 0; }
.quoteContainer { max-width: 800px; margin: 0 auto; }
.quote-text { font-size: var(--text-xl); border: none; font-style: italic; }
.quote-cite { display: block; font-size: var(--text-sm); font-style: normal; margin-top: var(--space-md); color: var(--color-dark-grey); }
.hiddenNow { opacity: 0; transition: opacity 0.3s; }
.hiddenNow.cycle-initialized { opacity: 1; }

/* ── Carousel ────────────────────────────────────────────── */
.scms-carousel .item img { width: 100%; height: auto; }

/* ── News Listing ────────────────────────────────────────── */
.news-item { margin-bottom: var(--space-xl); padding-bottom: var(--space-xl); border-bottom: 1px solid var(--color-mid-grey); }
.news-item:last-child { border-bottom: none; }
.news-thumb img { width: 100%; margin-bottom: var(--space-md); }
.news-title a { color: var(--color-text); text-decoration: none; }
.news-title a:hover { color: var(--color-primary); }
.news-meta { font-size: var(--text-sm); color: var(--color-dark-grey); margin-bottom: var(--space-sm); }

/* ── Video Banner ────────────────────────────────────────── */
.videoframe { position: relative; overflow: hidden; max-height: 90vh; }
.videoframe video { width: 100%; display: block; }

/* ── Footer Map ──────────────────────────────────────────── */
.footerMapWrap { width: 100%; }
#footerMap { width: 100%; height: 400px; }

/* ── Alert Popup ─────────────────────────────────────────── */
.popupAlert { padding: var(--space-lg); max-width: 600px; }
.popTitle { font-size: var(--text-xl); font-weight: 700; margin-bottom: var(--space-md); color: var(--color-primary); }
