/*B5v2.1 082025*/
/* --- 1. Global & Root --- */
@import url(https://fonts.bunny.net/css?family=montserrat:400,700|roboto:400,700);
:root {
  --white: #FFFFFF;
  --black: #000000;
  --primary: #002F6C; /*BRAND COLOR*/
  --secondary: #98D5FF; /*BRAND COLOR*/
  --success: #D5D5D5; /*BRAND COLOR*/
--light: color-mix(in srgb, var(--secondary) 90%, transparent 0%);
--dark: color-mix(in srgb, var(--primary), var(--black) 70%);
--danger: color-mix(in srgb, var(--black), var(--primary) 10%);
--warning: color-mix(in srgb, var(--black), var(--secondary) 20%);
--info: color-mix(in srgb, var(--primary), var(--secondary) 40%);
}
*{ box-sizing: border-box; }
html, body { background-color: var(--white); font-family: 'Roboto', sans-serif; font-size: 16px; font-weight: 400; -moz-osx-font-smoothing: grayscale; -webkit-font-smoothing: antialiased; overflow-x: hidden; }
a { color: inherit; text-decoration: none !important; }
a:hover { color: var(--primary); }
h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6, .display-2 { font-family: 'Montserrat', sans-serif; font-weight: 700; }
ul { list-style: none; margin: 0; padding: 0; }
p { color: var(--black); line-height: 25px; }
img { max-width: 100%; height: auto; }
ul.square-list { margin-inline-start: 20px; }
ul.square-list > li { list-style-type: square; }
.object-fit-cover { width: 100%; height: 100%; object-fit: cover; }
:focus-visible { outline: 2px dashed var(--primary); outline-offset: 1px; }
.offscreen { position: absolute; height: 1px; width: 1px; overflow: hidden; clip-path: inset(1px 1px 1px 1px); }
.skip-to-content.offscreen:focus { position: relative; display: inline; }
legend { font-size: 16px; margin-top: 15px; }
.form-group { margin-bottom: 15px !important; }

/* --- 2. Utilities --- */
.bg-dark { background-color: var(--black) !important; color: var(--white) !important; }
.bg-primary { background-color: var(--primary) !important; }
.bg-secondary { background-color: var(--secondary) !important; }
.bg-success { background-color: var(--success) !important; }
.bg-danger { background-color: var(--danger) !important; }
.bg-warning { background-color: var(--warning) !important; }
.bg-info { background-color: var(--info) !important; }
.bg-light { background-color: var(--light) !important; }
.bg-white { background-color: var(--white) !important; }
.bg-black { background-color: var(--black) !important; }
.text-primary { color: var(--primary) !important; }
.text-secondary { color: var(--secondary) !important; }
.text-success { color: var(--success) !important; }
.text-danger { color: var(--danger) !important; }
.text-warning { color: var(--warning) !important; }
.text-info { color: var(--info) !important; }
.text-dark { color: var(--dark) !important; }
.text-light { color: var(--light) !important; }
.text-white { color: var(--white) !important; }
.text-black { color: var(--black) !important; }
.border-primary { border-color: var(--primary) !important; }
.border-secondary { border-color: var(--secondary) !important; }
.border-success { border-color: var(--success) !important; }
.border-danger { border-color: var(--danger) !important; }
.border-warning { border-color: var(--warning) !important; }
.border-info { border-color: var(--info) !important; }
.border-dark { border-color: var(--dark) !important; }
.border-light { border-color: var(--light) !important; }
.border-white { border-color: var(--white) !important; }
.border-black { border-color: var(--black) !important; }

/* --- 3. Header (Revised for Flexible Height) --- */
.background-header { position: fixed !important; top: 0 !important; left: 0; right: 0; z-index: 100; transition: all .5s ease; }
.header-area { background-color: var(--white); position: relative; transition: all .5s ease; z-index: 100; }
.header-area .main-nav { display: flex; align-items: center; justify-content: space-between; padding: 5px 0; }
.header-area .main-nav .logo { flex-shrink: 0; }
.header-area .main-nav a.logo > img { display: block; height: 30px; width: auto; }
.header-area .main-nav .nav { display: none; align-items: center; gap: 15px; }
.header-area .main-nav .nav li a { display: block; color: var(--black); font-size: 15px; font-weight: 700; padding: 10px 0; transition: all 0.3s ease; }
.header-area .main-nav .nav li:hover a, .header-area .main-nav .nav li a.active { color: var(--primary) !important; }
.background-header .main-nav .nav li:hover a, .background-header .main-nav .nav li a.active { color: var(--primary) !important; }
.header-area .main-nav .nav li.has-sub { position: relative; padding-right: 15px; }
.header-area .main-nav .nav li.has-sub:after { color: var(--white); content: "\f107"; font-family: FontAwesome; font-size: 12px; position: absolute; right: 0; top: 50%; transform: translateY(-50%); }
.header-area .main-nav .nav li.has-sub:hover ul.sub-menu { opacity: 1; transform: translateY(0); visibility: visible; z-index: 1; }
.header-area .main-nav .nav li.has-sub ul.sub-menu { background: var(--white); box-shadow: 0 2px 28px rgba(0,0,0,.06); opacity: 0; position: absolute; top: 100%; transform: translateY(1em); transition: all .3s; visibility: hidden; width: 200px; }
.header-area .main-nav .nav li.has-sub ul.sub-menu li a { color: var(--black) !important; font-size: 13px; font-weight: 400; padding: 10px 20px; border-bottom: 1px solid var(--info); }
.header-area .main-nav .nav li.has-sub ul li a:hover { background: var(--success); color: var(--primary) !important; padding-left: 25px; }
.header-area .main-nav .menu-trigger { cursor: pointer; display: block; height: 40px; position: absolute; right: 10px; top: 50%; transform: translateY(-50%); text-indent: -9999em; width: 32px; z-index: 99; }
.header-area .main-nav .menu-trigger span, .header-area .main-nav .menu-trigger span:before, .header-area .main-nav .menu-trigger span:after { background-color: var(--black); display: block; height: 2px; position: absolute; transition: all 0.4s; width: 30px; }
.header-area .main-nav .menu-trigger span:before, .header-area .main-nav .menu-trigger span:after { content: ""; }
.header-area .main-nav .menu-trigger span { top: 16px; }
.header-area .main-nav .menu-trigger span:before { top: -10px; transform-origin: 33% 100%; }
.header-area .main-nav .menu-trigger span:after { top: 10px; transform-origin: 33% 0; }
.header-area .main-nav .menu-trigger.active span { background-color: transparent; }
.header-area .main-nav .menu-trigger.active span:before { background-color: var(--black); transform: translateY(6px) translateX(1px) rotate(45deg); }
.header-area .main-nav .menu-trigger.active span:after { background-color: var(--black); transform: translateY(-6px) translateX(1px) rotate(-45deg); }
.sub-header {font-size:.84rem;}

/* --- 4. Page Sections & Components --- */
section.heading-page, section.landing-header, section.donor-header { background-repeat: no-repeat; background-size: cover; padding: 230px 0 110px; text-align: center; }
section.heading-page { background-image: linear-gradient(rgba(0, 0, 0, 0.25), rgba(0, 0, 0, 0.25)), url(/assets/images/heading-bg.jpg); background-position: center 10%; }
section.landing-header { background-image: linear-gradient(rgba(0, 0, 0, 0.25), rgba(0, 0, 0, 0.25)), url(/assets/images/landing-bg.jpg); background-position: center 15%; }
section.donor-header { background-image: linear-gradient(rgba(0, 0, 0, 0.25), rgba(0, 0, 0, 0.25)), url(/assets/images/donor-bg.jpg); background-position: center center; }
section.heading-page h6, section.heading-page .h6, section.landing-header h6, section.landing-header .h6, section.donor-header h6, section.donor-header .h6 { color: var(--white); font-size: 15px; letter-spacing: 1px; margin-top: 0; }
section.heading-page h2, section.heading-page .h2, section.landing-header h2, section.landing-header .h2, section.donor-header h2, section.donor-header .h2 { color: var(--white); font-size: 36px; letter-spacing: 1px; margin: 20px 0; }
section.landing-page, section.donor-page, section.downloads-page { padding-top: 30px; padding-bottom: 0; }
.main-banner { position: relative; max-height: 600px; overflow: hidden; background-color: var(--black); height: calc(100vh - 41px); }
#bg-video { width: 100%; height: 600px; z-index: 0; overflow: hidden; }
.owl-main.owl-carousel .owl-item img { width: 100%; height: 600px; object-fit: cover; }
.video-overlay { background: linear-gradient(0deg, rgba(0,0,0,0) 0%, rgba(0,0,0,0) 0%); position: absolute; inset: 0; z-index: 1; pointer-events: none; }
.main-banner .caption { max-width: 425px; background-color: var(--light); z-index: 2; pointer-events: all; text-align: left; color: var(--dark) !important; }
.services { margin-top: -135px; position: absolute; width: 100%; }
.services .item { background: var(--primary); background-position: center; background-repeat: no-repeat; background-size: cover; border-radius: 20px; color: var(--white); padding: 40px; text-align: center; }
.services .item .icon { margin: 0 auto; max-width: 100px; }
.services .item p { color: var(--white); font-size: 13px; }
.services .item p.h4 > a { color: var(--white); font-size: 18px; font-weight: 700; margin: 25px 0 15px; }
.owl-custom-nav .owl-nav { display: none; }
.owl-custom-nav .owl-nav .owl-prev span, .owl-custom-nav .owl-nav .owl-next span { opacity: 0; }
.owl-custom-nav .owl-nav .owl-prev, .owl-custom-nav .owl-nav .owl-next { position: absolute; top: 50%; transform: translateY(-50%); outline: none; transition: opacity .5s; }
.owl-custom-nav .owl-nav .owl-prev:before, .owl-custom-nav .owl-nav .owl-next:before { background-color: var(--white); border-radius: 50%; color: var(--black); display: inline-block; font-family: 'FontAwesome'; font-size: 25px; font-weight: 700; height: 50px; line-height: 50px; width: 50px; }
.owl-custom-nav .owl-nav .owl-prev:hover, .owl-custom-nav .owl-nav .owl-next:hover { opacity: 0.9; }
.owl-custom-nav .owl-nav .owl-prev { left: -80px; }
.owl-custom-nav .owl-nav .owl-prev:before { content: '\f104'; }
.owl-custom-nav .owl-nav .owl-next { right: -85px; }
.owl-custom-nav .owl-nav .owl-next:before { content: '\f105'; }
.image-extend-right-wrapper { width: 100%; }
.image-extend-right-wrapper img { width: 100%; height: auto; display: block; }
.society-section { background-image: url('/assets/images/parallax.jpg'); background-attachment: fixed; background-position: center; background-repeat: no-repeat; background-size: cover; }
.contact-us { background-image: url('/assets/images/parallax.jpg'); background-attachment: fixed; background-position: center; background-repeat: no-repeat; background-size: cover; }
section.upcoming-how-to-give { background-color: var(--success); }
section.upcoming-how-to-give .categories { background-color: var(--white); margin-right: 45px; padding: 40px; }
section.upcoming-how-to-give .categories h3 { border-bottom: 1px solid var(--light); color: var(--primary); font-size: 18px; font-weight: 700; margin-bottom: 30px; padding-bottom: 20px; }
/* Card Base & Hover Interaction */
.transition { transition: all 0.35s ease-in-out; }
.give-item { border-top: 5px solid var(--primary) !important; border-radius: 8px; }
.give-item-lead-in {letter-spacing: 1.5px;font-weight:bold;}
.give-item:hover { transform: translateY(-8px); box-shadow: 0 15px 35px rgba(0,0,0,0.1) !important; }
/* Icon & Icon Box Styling */
.give-icon { fill: var(--primary) !important; height:30px; width:30px; transition: all 0.3s ease-in-out; }
.icon-box { background: var(--light) !important; border: 2px solid var(--primary) !important; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; height: 60px; width: 60px; transition: all 0.3s ease-in-out; }
.give-item:hover .icon-box { background: var(--primary) !important; border-color: var(--primary) !important; transform: scale(1.05); }
.give-item:hover .give-icon { fill: var(--white) !important; }
.our-courses .item .down-content { background-color: var(--white); height: 100%; }
.our-courses .item .down-content h3.h4 { border-bottom: 1px solid var(--light); color: var(--primary); font-size: 18px; padding: 25px; text-align: center; font-weight: 700; }
.our-courses .item .down-content .info { padding: 25px; }
.our-courses .item .down-content .info ul li { display: inline-block; margin-right: 1px; }
.our-courses .item .down-content .info ul li i { color: var(--primary); font-size: 14px; }
.our-courses .item .down-content .info span { color: var(--primary); display: inline-block; font-size: 15px; font-weight: 700; text-align: right; width: 100%; }
.our-courses .owl-dots { display: inline-block; margin-top: 40px; text-align: center; width: 100%; }
.our-courses .owl-dots .owl-dot { background-color: var(--white); border-radius: 50%; height: 7px; margin: 0px 5px; outline: none; transition: all .5s; width: 7px; }
.our-courses .owl-dots .active { border-radius: 4px; height: 8px; width: 24px; }
.services .owl-stage, #donors .owl-stage { display: flex; }
.services .owl-item, #donors .owl-item { display: flex; align-items: stretch; }
.services .item, #donors .item { height: 100%; }
.donors-section-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 0.5rem; }
.donor-controls { display: flex; align-items: center; gap: 10px; }
.donor-controls .custom-nav-btn { background: none; border: none; color: var(--info); font-size: 24px; cursor: pointer; padding: 5px; line-height: 1; }
.donor-controls .custom-nav-btn:hover { color: var(--dark); }
.donor-controls .owl-stop-button { width: 40px; height: 40px; background-color: var(--info); border: none; border-radius: 50%; color: var(--dark); font-size: 16px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background-color .3s; }
.donor-controls .owl-stop-button:hover { background-color: #ddd; }
#donors .card {border-radius: 0;}
section.contact-us #contact input:not([type='submit']) { background-color: var(--white); border: none; height: 40px; margin-bottom: 10px; outline: none; padding: 0px 15px; width: 100%; }
section.contact-us #contact textarea { background-color: var(--white); border: none; border-radius: 20px; color: #7a7a7a; font-size: 13px; margin-bottom: 30px; max-height: 180px; min-height: 140px; outline: none; padding: 15px; width: 100%; }
section.contact-us #contact button { background-color: var(--primary); border: none; color: var(--white); display: inline-block; font-size: 13px; font-weight: 700; outline: none; padding: 12px 30px; transition: all .3s; }
section.contact-us #contact button:hover { opacity: 0.9; }
section.contact-us .right-info-2 { background-color: var(--white); z-index: 2; pointer-events: all; text-align: left; color: var(--dark) !important; }
.contact-image { border-radius: 50%; max-width: 125px; margin-bottom: 1em; }
#radio1, #radio2, #radio3 { height: 15px !important; display: inline-block; width: auto !important; margin-bottom: 0 !important; }
#contactForm label, label { display: inline-block !important; }
._checkbox-radio { display: flex; }
._checkbox-radio input { width: 15px !important; height: 15px !important; }
.donor-image-wrapper { position: relative; overflow: hidden; width: 100%; padding-top: 75%; }
.donor-image-wrapper img { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover;border-radius:0}

/* --- 5. Buttons --- */
.btn { border-radius: 0px; text-align: left !important; }
.btn-primary {color: var(--white);border-color: var(--primary); background-color: var(--primary); cursor: pointer; transition: all 0.2s ease-in-out; }
.btn-primary:hover, .btn-primary:focus { color: var(--white); background-color: var(--black); border-color: var(--black); text-decoration: none; }
.btn-primary:focus { outline: 0; box-shadow: 0 0 0 0.25rem var(--light); }
.btn-primary:disabled, .btn-primary.disabled { color: var(--primary); background-color: transparent; border-color: var(--primary); opacity: 0.65; cursor: not-allowed; pointer-events: none; }

/* --- 6. Footer --- */
.footer-section { font-size: .75rem; padding: 1rem; }

/* --- 7. Media Queries --- */
@media (max-width: 991px) { .mobile-top-fix { margin-top: 30px; } .mobile-bottom-fix { margin-bottom: 30px; } .mobile-bottom-fix-big { margin-bottom: 60px; } .h-100 { height: auto !important; } .main-banner .caption h2 { font-size: 22px; margin-bottom: 10px; margin-top: 10px; } .services { margin-top: -135px; } section.upcoming-how-to-give { padding: 20px 0 0; } section.upcoming-how-to-give .categories { margin: 0 0 30px; } section.contact-us #contact { margin-bottom: 30px; } section.society-section { padding: 30px 0; } section.our-courses, section.contact-us { padding-top: 30px; padding-bottom: 20px; } }
@media (max-width: 767px) { .header-area { padding: 0 15px; } .header-area .main-nav .nav { display: none; flex-direction: column; position: absolute; top: 100%; left: 0; width: 100%; background: var(--white); } .header-area .main-nav .nav li { width: 100%; padding: 0 !important; border-bottom: 1px solid var(--info); } .header-area .main-nav .nav li:first-child { border-top: 1px solid var(--info); } .header-area .main-nav .nav li a { color: var(--dark) !important; padding: 15px 20px !important; height: auto !important; line-height: normal !important; } .header-area .main-nav .nav li a:hover { background: var(--success) !important; color: var(--primary) !important; } .header-area .main-nav .nav li.has-sub ul.sub-menu { display: none; } .display-2 { font-size: calc(1.2rem + 1.9vw); } .donor-controls { display: none; } }
@media (min-width: 768px) { .header-area .main-nav .nav { display: flex !important; } .header-area .main-nav .menu-trigger { display: none !important; } .owl-nav { display: none; } }
@media (min-width: 992px) { .image-extend-right-wrapper { width: calc(100% + 100px); } .image-extend-right-wrapper img { max-width: none; } .header-area .main-nav a.logo > img { height: 60px;} }
@media (min-width: 1006px) { .owl-custom-nav .owl-nav { display: block !important; } }

/* --- 8. Print Styles --- */
@media print {
  .print-logo { height: 75px; width: auto; margin: 0; }
  .print-header-text { font-size: 11px; align-self: center; }
  body, p, blockquote { font-size: 13px; line-height: 18px; }
  h1, .h1 { font-size: 28px; }
  h2, .h2 { font-size: 21px; }
  h3, .h3 { font-size: 18px; }
  h4, .h4 { font-size: 16px; }
  h5, .h5 { font-size: 14px; }
  h6, .h6 { font-size: 12px; }
  .mb-3 { margin-bottom: 10px !important; }
  .container { width: 100% !important; max-width: 100% !important; }
  .footer-section, .header-area, .sub-header, section.heading-page { display: none !important; }
  footer .btn { display: none !important; }
  html { height: 100%; }
  body { display: flex; flex-direction: column; min-height: 100%; }
  main { flex: 1 0 auto; }
  footer { flex-shrink: 0; padding-top: 2em; }
  footer .container, footer p { margin: 0 !important; padding: 0 !important; }
}
@page { size: 8.5in 11in; margin: .5in; }