/* === BTF Galleries v1.0.3 — also serves as site-wide font loader === */
@import url('https://fonts.googleapis.com/css2?family=Anton&family=Inter:wght@400;500;600;700&display=swap');

/* === SITE-WIDE FONT OVERRIDE === */
.elementor .elementor-heading-title,
.elementor-heading-title,
.elementor-widget-button .elementor-button,
h1.elementor-heading-title, h2.elementor-heading-title, h3.elementor-heading-title,
h4.elementor-heading-title, h5.elementor-heading-title, h6.elementor-heading-title{
  font-family: "Anton", "Oswald", "Arial Narrow", sans-serif !important;
  font-weight: 400 !important;
}
.elementor-widget-text-editor, .elementor-widget-text-editor p, .elementor-widget-text-editor li{
  font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
}

/* === Gallery plugin styles === */
.btf-gallery { margin: 24px 0 32px; font-family: Inter, sans-serif; color: #1A1A1A; }
.btf-gallery * { box-sizing: border-box; }
.btf-gallery-title { font-family: Anton, "Oswald", sans-serif !important; font-size: clamp(22px, 3.5vw, 28px); font-weight: 400 !important; color: #7A092B; margin: 0 0 14px; letter-spacing: 0.5px; text-transform: uppercase; }
.btf-gallery-meta { display: flex; justify-content: flex-end; font-size: 13px; color: #777; margin: 0 0 14px; }
.btf-count-shown, .btf-count-total { font-weight: 600; color: #444; }
.btf-empty { background: #F6F1F1; border: 1px dashed rgba(122,9,43,.25); padding: 36px 24px; border-radius: 8px; text-align: center; color: #555; }
.btf-empty-icon { font-size: 32px; margin-bottom: 8px; opacity: .5; }
.btf-empty p { margin: 0; font-style: italic; }
.btf-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(min(100%, 240px), 1fr)); gap: 14px; }
@media (max-width: 720px) { .btf-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; } }
@media (max-width: 440px) { .btf-grid { grid-template-columns: 1fr; gap: 12px; } }

/* IMPORTANT: all .btf-card rules below are SCOPED to .btf-gallery to avoid colliding with sitewide .btf-card class on callout sections (which is added by BTF_HEAD JS classify()) */
.btf-gallery .btf-card { position: relative; margin: 0; border-radius: 8px; overflow: hidden; background: #1A1A1A; box-shadow: 0 3px 12px rgba(0,0,0,.10); transition: transform .3s cubic-bezier(.2,.7,.3,1), box-shadow .3s ease; aspect-ratio: 3 / 2; animation: btf-card-in .35s ease both; }
@keyframes btf-card-in { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.btf-gallery .btf-card:hover, .btf-gallery .btf-card:focus-within { transform: translateY(-3px); box-shadow: 0 10px 28px rgba(0,0,0,.18); }
.btf-card-link { display: block; width: 100%; height: 100%; position: relative; line-height: 0; text-decoration: none; color: inherit; cursor: zoom-in; }
.btf-card-link img { display: block; width: 100%; height: 100%; object-fit: cover; transition: transform .55s cubic-bezier(.2,.7,.3,1); }
.btf-gallery .btf-card:hover .btf-card-link img, .btf-gallery .btf-card:focus-within .btf-card-link img { transform: scale(1.05); }
.btf-card-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,0.78) 0%, rgba(0,0,0,0.45) 30%, transparent 65%); opacity: 0; transition: opacity .3s ease; pointer-events: none; }
.btf-gallery .btf-card:hover .btf-card-overlay, .btf-gallery .btf-card:focus-within .btf-card-overlay { opacity: 1; }
.btf-card-caption { position: absolute; left: 0; right: 0; bottom: 0; padding: 12px 14px; color: #fff; font-size: 13px; font-family: Inter, sans-serif; line-height: 1.35; font-weight: 500; text-shadow: 0 1px 4px rgba(0,0,0,.5); opacity: 0; transform: translateY(6px); transition: opacity .3s ease, transform .3s ease; pointer-events: none; }
.btf-gallery .btf-card:hover .btf-card-caption, .btf-gallery .btf-card:focus-within .btf-card-caption { opacity: 1; transform: translateY(0); }
@media (hover: none) { .btf-gallery .btf-card-overlay { opacity: 1; background: linear-gradient(to top, rgba(0,0,0,0.7), transparent 50%); } .btf-gallery .btf-card-caption { opacity: 1; transform: none; } }
.btf-card-delete { position: absolute !important; top: 8px !important; right: 8px !important; width: 32px !important; height: 32px !important; padding: 0 !important; border-radius: 50% !important; background: rgba(0,0,0,0.7) !important; color: #fff !important; border: 1.5px solid rgba(255,255,255,0.5) !important; font-size: 20px !important; line-height: 1 !important; font-family: Arial, sans-serif !important; cursor: pointer !important; z-index: 3 !important; opacity: 0; transform: scale(0.85); transition: opacity .2s ease, transform .2s ease, background .2s ease !important; display: flex !important; align-items: center !important; justify-content: center !important; font-weight: 300 !important; }
.btf-gallery .btf-card:hover .btf-card-delete, .btf-gallery .btf-card:focus-within .btf-card-delete { opacity: 1; transform: scale(1); }
@media (hover: none) { .btf-gallery .btf-card-delete { opacity: 1; transform: scale(1); } }
.btf-card-delete:hover { background: #E34614 !important; border-color: #fff !important; transform: scale(1.1) !important; }
.btf-load-more-wrap { text-align: center; margin: 26px 0 6px; }
.btf-load-more-wrap[hidden] { display: none; }
.btf-load-more { background: transparent !important; color: #7A092B !important; border: 2px solid #7A092B !important; padding: 12px 28px !important; border-radius: 4px !important; font-family: Anton, sans-serif !important; font-weight: 400 !important; text-transform: uppercase !important; font-size: 14px !important; letter-spacing: 1px !important; cursor: pointer !important; transition: all .25s !important; display: inline-block !important; }
.btf-load-more:hover { background: #7A092B !important; color: #fff !important; transform: translateY(-2px); box-shadow: 0 6px 18px rgba(122,9,43,.28); }
.btf-load-spinner { display: none; width: 18px; height: 18px; border: 2px solid rgba(122,9,43,.25); border-top-color: #7A092B; border-radius: 50%; margin-left: 10px; vertical-align: middle; animation: btf-spin .8s linear infinite; }
.btf-load-more-wrap.is-loading .btf-load-spinner { display: inline-block; }
@keyframes btf-spin { to { transform: rotate(360deg); } }
.btf-uploader { text-align: center; margin-top: 30px; }
.btf-uploader-toggle { background: #E34614 !important; color: #fff !important; border: none !important; padding: 13px 30px !important; border-radius: 4px !important; font-family: Anton, sans-serif !important; font-weight: 400 !important; text-transform: uppercase !important; font-size: 14px !important; letter-spacing: 1px !important; cursor: pointer !important; transition: all .25s !important; box-shadow: 0 5px 16px rgba(227,70,20,.28) !important; line-height: 1.4 !important; display: inline-block !important; }
.btf-uploader-toggle:hover { transform: translateY(-2px); box-shadow: 0 10px 24px rgba(227,70,20,.45) !important; background: #c93f12 !important; }
.btf-uploader-form { display: none; background: #F6F1F1; border-left: 4px solid #7A092B; padding: 24px 28px; margin: 20px auto 0; border-radius: 6px; max-width: 540px; text-align: left; box-shadow: 0 6px 28px rgba(0,0,0,.08); }
.btf-uploader-form.is-open { display: block; }
.btf-uploader-heading { margin: 0 0 18px; font-family: Anton, sans-serif !important; font-weight: 400; font-size: 20px; color: #7A092B; text-transform: uppercase; letter-spacing: 0.5px; }
.btf-uploader-field { display: block; margin-bottom: 16px; }
.btf-uploader-label { display: block; font-size: 13px; font-weight: 600; color: #333; margin-bottom: 6px; }
.btf-uploader-label small { font-weight: 400; color: #888; }
.btf-uploader-form input[type="file"], .btf-uploader-form input[type="text"] { display: block; width: 100%; padding: 11px 12px; border: 1px solid #ddd; border-radius: 4px; font-family: Inter, sans-serif; font-size: 14px; background: #fff; }
.btf-uploader-form input[type="file"] { padding: 9px; }
.btf-uploader-actions { display: flex; gap: 10px; margin-top: 6px; flex-wrap: wrap; }
.btf-uploader-form button { border: none !important; padding: 11px 22px !important; border-radius: 4px !important; font-family: Anton, sans-serif !important; font-weight: 400 !important; text-transform: uppercase !important; font-size: 13px !important; letter-spacing: 0.7px !important; cursor: pointer !important; flex: 1 1 auto; min-width: 120px; }
.btf-uploader-submit { background: #E34614 !important; color: #fff !important; }
.btf-uploader-cancel { background: transparent !important; color: #7A092B !important; border: 1px solid #7A092B !important; }
.btf-uploader-status { margin-top: 14px; padding: 10px 14px; border-radius: 4px; font-size: 13px; display: none; }
.btf-uploader-status.is-info { background: #fff8e1; color: #7a5b00; display: block; }
.btf-uploader-status.is-success { background: #d4edda; color: #155724; display: block; }
.btf-uploader-status.is-error { background: #f8d7da; color: #721c24; display: block; }
.btf-lightbox { position: fixed; inset: 0; background: rgba(0,0,0,0.95); z-index: 99999; display: flex; align-items: center; justify-content: center; animation: btf-fade .2s ease; padding: 20px; }
.btf-lightbox-stage { position: relative; max-width: 100%; max-height: 100%; display: flex; align-items: center; justify-content: center; }
.btf-lightbox-img { max-width: min(92vw, 1400px); max-height: 82vh; object-fit: contain; border-radius: 4px; box-shadow: 0 14px 60px rgba(0,0,0,.7); }
.btf-lightbox-img.is-loading { opacity: .4; }
.btf-lightbox-caption { position: absolute; left: 50%; bottom: -50px; transform: translateX(-50%); background: rgba(0,0,0,0.65); color: #fff; padding: 8px 18px; border-radius: 22px; font-size: 14px; max-width: 88vw; font-family: Inter, sans-serif; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.btf-lightbox-counter { position: absolute; top: 20px; left: 24px; color: rgba(255,255,255,.85); font-size: 14px; font-family: Inter, sans-serif; background: rgba(0,0,0,.4); padding: 5px 12px; border-radius: 16px; }
.btf-lightbox-close, .btf-lightbox-prev, .btf-lightbox-next { position: absolute; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.22); color: #fff; border-radius: 50%; cursor: pointer; transition: background .2s, transform .2s; display: flex; align-items: center; justify-content: center; padding: 0; }
.btf-lightbox-close { top: 18px; right: 22px; width: 44px; height: 44px; font-size: 28px; }
.btf-lightbox-prev, .btf-lightbox-next { top: 50%; transform: translateY(-50%); width: 52px; height: 52px; font-size: 28px; }
.btf-lightbox-prev { left: 22px; }
.btf-lightbox-next { right: 22px; }
.btf-lightbox-close:hover, .btf-lightbox-prev:hover, .btf-lightbox-next:hover { background: rgba(255,255,255,.18); }
@media (max-width: 600px) { .btf-lightbox { padding: 8px; } .btf-lightbox-img { max-width: 96vw; max-height: 70vh; } .btf-lightbox-close { top: 12px; right: 12px; width: 40px; height: 40px; } .btf-lightbox-prev, .btf-lightbox-next { width: 44px; height: 44px; font-size: 22px; top: auto; bottom: 20px; transform: none; } .btf-lightbox-prev { left: 12px; } .btf-lightbox-next { right: 12px; } .btf-lightbox-caption { bottom: 70px; font-size: 13px; padding: 6px 14px; } .btf-lightbox-counter { top: 14px; left: 14px; font-size: 12px; padding: 4px 10px; } }
@keyframes btf-fade { from { opacity: 0; } to { opacity: 1; } }
