/*
 Theme Name:  Divi Child Theme
 Theme URI:  http://elegantthemes.com/
 Description: Divi Child Theme
 Author:    ElegantThemes
 Author URI:  http://elegantthemes.com
 Template:   Divi
 Version:   4.2.0
 License:   GNU General Public License v2 or later
 License URI: http://www.gnu.org/licenses/gpl-2.0.html
 Tags: responsive-layout, one-column, two-columns, three-columns, four-columns, left-sidebar, right-sidebar, custom-background, custom-colors, featured-images, full-width-template, post-formats, rtl-language-support, theme-options, threaded-comments, translation-ready
 Text Domain: divi-child-theme
*/

/* ==========================================================
   HANKEN GROTESK NAVS — SELF-HOSTED WEBFONTS
   ========================================================== */

@font-face {
  font-family: 'Hanken Grotesk Navs';
  src: url('/wp-content/themes/fonts/HankenGrotesk-Navs-Regular-fixed.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Hanken Grotesk Navs';
  src: url('/wp-content/themes/fonts/HankenGrotesk-Navs-Medium-fixed.woff2') format('woff2');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Hanken Grotesk Navs';
  src: url('/wp-content/themes/fonts/HankenGrotesk-Navs-SemiBold-fixed.woff2') format('woff2');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Hanken Grotesk Navs';
  src: url('/wp-content/themes/fonts/HankenGrotesk-Navs-Bold-fixed.woff2') format('woff2');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

/* ==========================================================
   GLOBAL TYPOGRAPHY SYSTEM
   Scoped for front-end content only
   ========================================================== */

:root {
  --brand-blue: #5aafe0;
  --h6-colour: #414644;
  --font-sans: 'Hanken Grotesk Navs', system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  --font-ivy: "ivypresto-display", serif;
}

/* Force Navs font across all elements, overriding any Divi inline font-family */
* {
  font-family: 'Hanken Grotesk Navs', system-ui, -apple-system, sans-serif !important;
}

/* Preserve Ivy Presto on H4 */
.et_pb_text h4,
.et_pb_blurb_content h4,
.et_pb_toggle_content h4,
.et_pb_tab h4,
.et_pb_accordion_item h4,
.et_pb_slide_description h4,
.et_pb_post h4,
.entry-content h4,
.et-l--body h4 {
  font-family: var(--font-ivy) !important;
}

/* =================================
   CONTENT WRAPPERS ONLY
   ================================= */

.et_pb_text,
.et_pb_blurb_content,
.et_pb_toggle_content,
.et_pb_tab,
.et_pb_accordion_item,
.et_pb_slide_description,
.et_pb_post,
.entry-content,
.et-l--body {
  font-family: var(--font-sans);
}

/* =================================
   HEADINGS BASE
   ================================= */

.et_pb_text h1,
.et_pb_text h2,
.et_pb_text h3,
.et_pb_text h4,
.et_pb_text h5,
.et_pb_blurb_content h1,
.et_pb_blurb_content h2,
.et_pb_blurb_content h3,
.et_pb_blurb_content h4,
.et_pb_blurb_content h5,
.et_pb_toggle_content h1,
.et_pb_toggle_content h2,
.et_pb_toggle_content h3,
.et_pb_toggle_content h4,
.et_pb_toggle_content h5,
.et_pb_tab h1,
.et_pb_tab h2,
.et_pb_tab h3,
.et_pb_tab h4,
.et_pb_tab h5,
.et_pb_accordion_item h1,
.et_pb_accordion_item h2,
.et_pb_accordion_item h3,
.et_pb_accordion_item h4,
.et_pb_accordion_item h5,
.et_pb_slide_description h1,
.et_pb_slide_description h2,
.et_pb_slide_description h3,
.et_pb_slide_description h4,
.et_pb_slide_description h5,
.et_pb_post h1,
.et_pb_post h2,
.et_pb_post h3,
.et_pb_post h4,
.et_pb_post h5,
.entry-content h1,
.entry-content h2,
.entry-content h3,
.entry-content h4,
.entry-content h5,
.et-l--body h1,
.et-l--body h2,
.et-l--body h3,
.et-l--body h4,
.et-l--body h5 {
  color: var(--brand-blue) !important;
  font-family: var(--font-sans) !important;
  font-weight: 600 !important;
  line-height: 1.1;
  margin: 0 0 0.6em 0;
  letter-spacing: -0.02em;
}

/* =================================
   H1
   ================================= */

.et_pb_text h1,
.et_pb_blurb_content h1,
.et_pb_toggle_content h1,
.et_pb_tab h1,
.et_pb_accordion_item h1,
.et_pb_slide_description h1,
.et_pb_post h1,
.entry-content h1,
.et-l--body h1 {
  font-size: clamp(3.4rem, 2.2rem + 4vw, 5.6rem) !important;
  font-weight: 700 !important;
  line-height: 1.03;
  letter-spacing: -0.03em;
}

/* =================================
   H2
   ================================= */

.et_pb_text h2,
.et_pb_blurb_content h2,
.et_pb_toggle_content h2,
.et_pb_tab h2,
.et_pb_accordion_item h2,
.et_pb_slide_description h2,
.et_pb_post h2,
.entry-content h2,
.et-l--body h2 {
  font-size: clamp(2.6rem, 1.9rem + 2.6vw, 3.8rem) !important;
  font-weight: 700 !important;
}

/* =================================
   H3
   ================================= */

.et_pb_text h3,
.et_pb_blurb_content h3,
.et_pb_toggle_content h3,
.et_pb_tab h3,
.et_pb_accordion_item h3,
.et_pb_slide_description h3,
.et_pb_post h3,
.entry-content h3,
.et-l--body h3 {
  font-size: clamp(2rem, 1.5rem + 1.9vw, 2.8rem) !important;
  font-weight: 600 !important;
}

/* =================================
   H4
   ================================= */

.et_pb_text h4,
.et_pb_blurb_content h4,
.et_pb_toggle_content h4,
.et_pb_tab h4,
.et_pb_accordion_item h4,
.et_pb_slide_description h4,
.et_pb_post h4,
.entry-content h4,
.et-l--body h4 {
  font-family: var(--font-ivy) !important;
  font-style: italic !important;
  font-weight: 400 !important;
  font-size: clamp(2.6rem, 1.9rem + 2.6vw, 3.8rem) !important;
  line-height: 1.1;
  letter-spacing: -0.01em;
}

/* =================================
   H5
   ================================= */

.et_pb_text h5,
.et_pb_blurb_content h5,
.et_pb_toggle_content h5,
.et_pb_tab h5,
.et_pb_accordion_item h5,
.et_pb_slide_description h5,
.et_pb_post h5,
.entry-content h5,
.et-l--body h5 {
  font-size: clamp(1.4rem, 1.2rem + 0.8vw, 1.8rem) !important;
  font-weight: 600 !important;
}

/* =================================
   H6
   ================================= */

.et_pb_text h6,
.et_pb_blurb_content h6,
.et_pb_toggle_content h6,
.et_pb_tab h6,
.et_pb_accordion_item h6,
.et_pb_slide_description h6,
.et_pb_post h6,
.entry-content h6,
.et-l--body h6 {
  color: var(--h6-colour) !important;
  font-family: var(--font-sans) !important;
  font-weight: 600 !important;
  font-size: clamp(1.15rem, 1rem + 0.5vw, 1.35rem) !important;
  letter-spacing: -0.01em;
}

/* =================================
   PARAGRAPHS
   ================================= */

.et_pb_text p,
.et_pb_blurb_content p,
.et_pb_toggle_content p,
.et_pb_tab p,
.et_pb_accordion_item p,
.et_pb_slide_description p,
.et_pb_post p,
.entry-content p,
.et-l--body p {
  font-family: var(--font-sans) !important;
  font-weight: 550 !important;
  line-height: 1.5;
  letter-spacing: -0.02em;
  margin-bottom: 1em;
}

/* =================================
   LISTS
   ================================= */

.et_pb_text ol,
.et_pb_text ul,
.et_pb_blurb_content ol,
.et_pb_blurb_content ul,
.et_pb_toggle_content ol,
.et_pb_toggle_content ul,
.et_pb_tab ol,
.et_pb_tab ul,
.et_pb_accordion_item ol,
.et_pb_accordion_item ul,
.et_pb_slide_description ol,
.et_pb_slide_description ul,
.et_pb_post ol,
.et_pb_post ul,
.entry-content ol,
.entry-content ul,
.et-l--body ol,
.et-l--body ul {
  list-style: none;
  font-family: var(--font-sans) !important;
  font-weight: 700 !important;
  padding-left: 0;
  margin-left: 0;
}

/* =================================
   HERO / LARGE HEADING UTILITIES
   ================================= */

.hero-heading h1 {
  font-size: clamp(4.5rem, 3rem + 5vw, 7.5rem) !important;
  line-height: 0.98 !important;
  letter-spacing: -0.035em !important;
}

.hero-heading h4 {
  font-size: clamp(4rem, 2.8rem + 4.5vw, 6.5rem) !important;
  line-height: 1 !important;
  letter-spacing: -0.02em !important;
}

.hero-heading h1,
.hero-heading h4 {
  margin-bottom: 0.3em !important;
}

/* =========================================
   WooCommerce product archive title fix
   ========================================= */

.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce-page ul.products li.product .woocommerce-loop-product__title,
.woocommerce .products ul li.product .woocommerce-loop-product__title,
.woocommerce-page .products ul li.product .woocommerce-loop-product__title {
  font-size: clamp(1.1rem, 0.95rem + 0.6vw, 1.6rem) !important;
  line-height: 1.2 !important;
  font-weight: 700 !important;
  margin: 12px 0 8px 0 !important;
  padding: 0 !important;
}

.woocommerce ul.products li.product .price,
.woocommerce-page ul.products li.product .price {
  font-size: 1rem !important;
  line-height: 1.3 !important;
  margin-top: 0 !important;
}

.woocommerce ul.products li.product .star-rating,
.woocommerce-page ul.products li.product .star-rating {
  font-size: 0.9rem !important;
  margin: 8px 0 6px 0 !important;
}

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  margin-bottom: 2.5em !important;
}

/* =========================================
   WooCommerce Order Confirmation Message
   ========================================= */

.woocommerce-notice.woocommerce-notice--success.woocommerce-thankyou-order-received {
  font-size: clamp(1.8rem, 1.4rem + 1.5vw, 2.6rem) !important;
  font-weight: 700 !important;
  color: #5aafe0 !important;
  line-height: 1.2 !important;
  margin-bottom: 1.2em !important;
  padding: 12px 16px !important;
  background: rgba(90, 175, 224, 0.08);
  border-left: 4px solid #5aafe0;
  border-radius: 4px;
}

/* ==========================================================
   NAV
   ========================================================== */

.nav > li > a {
    position: relative;
    display: block;
    padding: 0 15px;
}

.nav > li > a:hover, .nav > li > a:focus {
    background-color: unset;
}

#faqs .et_pb_blurb_content {
    max-width: unset;
}

/* ==========================================================
   GIVING / DONATION FORMS
   ========================================================== */

.giving-h4 h4 {
    font-family: 'Hanken Grotesk Navs', sans-serif;
    font-style: normal;
    font-size: 93px !important;
    font-weight: 500;
    letter-spacing: -0.25rem !important;
}

#repGivingFormHeader {
    width: 44%;
    float: left;
    padding-right: 40px;
}

#repGivingFormHeader h2 {
    font-size: 52px !important;
    line-height: 1.15 !important;
}

#repGivingFormIntro {
    width: 56%;
    float: left;
    padding-left: 20px;
}

#repGivingCode {
    clear: both;
}

section.content-section.gfmessage { text-align: left; background: #58aede; display: block; padding: 1px 24px 24px 24px; margin: 0 0 30px 0; color: #ffffff; }
section.content-section.gfmessage h3, section.content-section.gfmessage p { background: #58aede; color: #ffffff; }

#donorfyDonation {
    max-width: 1280px;
    padding-bottom: 80px;
}

#donorfyDonation.donorfyDonation-1col {
    max-width: 810px;
}

#donorfyDonation.donorfyDonation-2col > div:nth-of-type(2),
#donorfyDonation.donorfyDonation-1col {
    border-radius: 0;
    padding: 20px 50px 20px 50px;
    margin: 0 auto 85px auto;
    text-align: center;
    border: 4px solid #58aede;
}

#donorfyDonation #widgetID {
    display: none;
}

#donorfyDonation h2 {
    text-align: center;
    font-weight: 600;
    line-height: 1.2;
    text-align: left;
    letter-spacing: -0.075rem;
    margin: 0 0 40px 0;
    padding: 0;
    font-size: 46px;
}

#donorfyDonation h3 {
    font-size: 38px;
    font-weight: 600;
    letter-spacing: -0.075rem;
    margin-bottom: 12px;
}

#donorfyDonation p {
    text-align: left;
    color: #58aede;
    letter-spacing: -0.03rem;
    font-size: 23px;
    max-width: 600px;
    font-weight: 500;
    line-height: 1.35;
}

#donorfyDonation #repGivingFormIntro p {
    font-size: 18px;
    color: #231f20;
    letter-spacing: 0;
}

#donorfyDonation .et_pb_column .et_pb_text {
    margin: 0 0 20px;
}

#donorfyDonation #itemList.active, #donorfyDonation #targetFund.active, #donorfyDonation .controlsRow #customAmount.active {
    display: inline-block;
}

#donorfyDonation .controlsRow #customAmount {
    display: none;
}

#donorfyDonation #itemList li {
    list-style-type: none;
    cursor: pointer;
    font-size: 16px;
    font-family: 'Hanken Grotesk Navs', sans-serif;
    color: #231f20;
    padding: 2px 0;
}

#donorfyDonation #itemList li strong {
    font-weight: normal;
}

#donorfyDonation #itemList li.persist:nth-child(2) {
    padding-bottom: 10px;
    border-bottom: 1px dotted #58aede;
    margin: 0 0 10px 0;
}

#donorfyDonation #itemList li:hover {
    color: #58aede;
}

#donorfyDonation #itemList li.persist, #donorfyDonation .donationFrame.active {
    display: block !important;
}

#donorfyDonation #itemList, #targetFund, #donorfyDonation #oneoffTemp, #donorfyDonation #monthlyTemp, #donorfyDonation .donationFrame {
    display: none;
}

#donorfyDonation #targetFund {
    clear: both;
    width: 100%;
    text-align: left;
    max-width: 100%;
    padding: 25px 0 25px 30px;
    font-size: 18px;
    color: #231f20;
    position: absolute;
    left: 0;
    top: -35px;
    font-family: 'Hanken Grotesk Navs', sans-serif;
}

#donorfyDonation #targetFund:before {
    content: "\4e";
    background: #58aede;
    font-family: ETmodules !important;
    font-weight: 400 !important;
    color: #ffffff;
    border-radius: 100%;
    height: 30px;
    width: 30px;
    padding: 4px 4px 2px 2px;
    margin: 0px 10px 0 -30px;
}

#donorfyDonation.donorfyDonation-1col input#fundSelect {
    display: inline-block;
    background-color: transparent;
    padding: 18.5px 14px;
    width: 100%;
    max-width: 300px;
    border: 4px solid #58aede;
    font-family: 'Hanken Grotesk Navs', sans-serif !important;
    font-weight: 500;
    font-size: 18px;
    margin-right: 100%;
    position: absolute;
    left: 0;
    top: -95px;
}

#donorfyDonation.donorfyDonation-1col .controls {
    margin-top: -40px;
}

#donorfyDonation input#fundSelect:focus,
#donorfyDonation input#fundSelect:active {
    background-color: #58aede20 !important;
}

#donorfyDonation input#fundSelect::placeholder {
    font-family: 'Hanken Grotesk Navs', sans-serif !important;
    font-size: 18px;
    color: #231F20;
    font-weight: 500;
}

#donorfyDonation #itemList {
    overflow-y: scroll;
    background-color: #f5f5f5;
    max-height: 298px;
    width: 100%;
    max-width: 300px;
    margin: 0 auto;
    text-align: left;
    border: 4px solid #58aede;
    padding: 10px;
    position: absolute;
    top: -31px;
    left: 0;
    scrollbar-color: #58aede transparent;
    scrollbar-width: thin;
    margin-right: 100%;
}

#donorfyDonation #itemList::-webkit-scrollbar {
    width: 14px;
}

#donorfyDonation #itemList::-webkit-scrollbar-track {
    background: transparent;
}

#donorfyDonation #itemList::-webkit-scrollbar-thumb {
    background-color: #58aede80;
    border-radius: 20px;
    border: 4px solid #f5f5f5;
}

#donorfyDonation .controls {
    padding: 0 0 20px 0;
    width: 100%;
    margin: 0 auto;
}

#donorfyDonation .controls ul {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 25px 12px;
    padding: 0;
    margin: 0;
}

#donorfyDonation .controls ul li, #donorfyDonation .donation-options .option {
    list-style-type: none;
    padding: 14px 14px;
    border: 4px solid #58aede;
    cursor: pointer;
    flex-direction: column;
    cursor: pointer;
    display: flex;
    justify-content: center;
    text-align: left;
    font-family: 'Hanken Grotesk Navs', sans-serif;
}

#donorfyDonation .controls ul li:hover, #donorfyDonation .donation-options .option:hover {
    background: #f5f5f5;
    color: #ffffff;
}

#donorfyDonation .controls ul li span, #donorfyDonation .donation-options .option p {
    color: #58aede;
    font-size: 20px;
    text-align: left;
    font-weight: 600;
}

#donorfyDonation .controls ul li.active, #donorfyDonation .donation-options .option.active {
    background: #58aede;
}

#donorfyDonation .controls ul li.active span, #donorfyDonation .donation-options .option.active p {
    color: #ffffff;
}

#donorfyDonation .donation-options {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 25px 12px;
    padding: 0;
    margin: 0 auto;
}

#donorfyDonation .donationFrame {
    width: 100%;
    margin: 0 auto;
}

#donorfyDonation .controlsRow {
    color: #58aede;
    font-weight: 600;
    cursor: pointer;
    font-family: 'Hanken Grotesk Navs', sans-serif;
    font-size: 20px;
    border: 4px solid #58aede;
    flex-direction: column;
    justify-content: center !important;
    display: flex;
    letter-spacing: -0.03rem;
}

#donorfyDonation .donation-options.conceal, #donorfyDonation .controlsRow label.conceal {
    display: none;
}

#donorfyDonation .controlsRow ul li {
    list-style-type: none;
    text-align: left;
    line-height: 1;
}

#donorfyDonation .controlsRow ul {
    padding: 0 0 0 0;
}

#donorfyDonation #customAmount {
    display: inline-block;
    padding: 14px 14px;
    width: 100%;
    max-width: 480px;
    margin: 0 auto;
    border: none;
    font-family: 'Hanken Grotesk Navs', sans-serif;
    font-weight: 600;
    font-size: 20px;
    color: #58aede;
}

#donorfyDonation #otherAmount label {
    padding: 18.5px 5px 18.5px 14px;
    display: block;
    font-size: 18px;
}

#donorfyDonation #otherAmount label.conceal {
    display: none;
}

#donorfyDonation #customAmount.active {
    background-color: #58aede20 !important;
}

#donorfyDonation #customAmount::placeholder {
    color: #58aede;
}

#donorfyDonation .buttonRow {
    list-style-type: none;
    padding: 14px;
    color: #ffffff;
    background: #58aede;
    border: 2px solid #58aede;
    cursor: pointer;
    width: calc(25% - 10px);
    float: right;
    margin: 20px 0 20px 0;
    font-family: 'Hanken Grotesk Navs', sans-serif;
    font-size: 20px;
    font-weight: 600;
    text-align: left;
}

#donorfyDonation .buttonRow:hover {
    background: #58aede;
    color: #ffffff;
    border: 2px solid #58aede;
}

#donorfyDonation.donorfyresult .et_pb_button:after {
    content: "";
}

#donorfyDonation.donorfyresult .et_pb_button {
    list-style-type: none;
    padding: 14px 9px 14px 0;
    color: #ffffff;
    background: #58aede;
    border: 2px solid #58aede;
    cursor: pointer;
    width: auto;
    margin: 20px 30px 20px 0 !important;
    font-family: 'Hanken Grotesk Navs', sans-serif;
    font-size: 20px;
    font-weight: 600;
    letter-spacing: 0;
}

#donorfyDonation.donorfyresult .et_pb_button:hover {
    background: #58aede;
    color: #ffffff !important;
    border: 2px solid #58aede;
}

#donorfyDonation.donorfyresult .et_pb_social_network_link a.icon {
    border-radius: 25px 25px 25px 25px !important;
}

#donorfyDonation small {
    display: none;
    max-width: 400px;
    text-align: left;
    position: relative;
    top: -33px;
    font-family: 'Hanken Grotesk Navs', sans-serif;
    font-size: 14px;
    font-weight: 400;
    line-height: 20px;
}

#donorfyDonation small.active {
    display: inline-block;
}

small#note::before {
    content: "i";
    background: #3a4d6d;
    font-weight: 400 !important;
    color: #ffffff;
    border-radius: 100%;
    height: 19px;
    width: 19px;
    padding: 0px 0 0 0;
    margin: 0px 10px 0 -30px;
    display: inline-block;
    text-align: center;
}

.donationForm {
    background-color: transparent;
    padding: 40px 10px 20px 20px;
    margin: 54px auto 85px auto;
    width: 90%;
    max-width: 900px;
    border: 4px solid #58aede;
    text-align: center;
    font-family: 'Hanken Grotesk Navs', sans-serif;
}

.donationForm section .row {
    overflow: hidden;
    padding-bottom: 0;
}

.donationForm section {
    position: relative;
}

.donationForm section.bill {
    margin: 0;
}

.donationForm section.bill .row {
    padding: 0;
}

.donationForm form {
    padding: 0 30px 0 30px;
}

.donationForm strong {
    color: #58aede;
    font-size: 18px;
}

.donationForm .col-md-6, .donationForm .col-md-4, .donationForm .col-md-12 {
    padding: 0 0 20px 0;
    text-align: left;
}

.donationForm h3 {
    font-size: 24px;
    font-weight: 600;
    padding: 10px 0;
    margin-top: 30px;
    letter-spacing: -0.04rem;
    color: #58aede;
}

.donationForm p, .donationForm label, .donationForm i, .donationForm .radiogroup span {
    color: #212121;
    font-size: 18px;
    text-align: left;
    font-weight: 500;
}

.donationForm #bill {
    width: 100%;
    margin: 30px 0 30px 0;
    border-radius: 15px;
    text-align: left;
}

.donationForm #bill p {
    font-size: 26px;
    line-height: 1.2;
    font-weight: 600;
}

.donationForm #bill .minor {
    color: #58aede;
}

.donationForm #bill .minor a {
    text-decoration: underline;
}

.donationForm .donate-button, .donationForm #submitButton {
    list-style-type: none;
    padding: 14px 9px 14px 0;
    color: #ffffff;
    background: #58aede;
    border: 2px solid #58aede;
    cursor: pointer;
    width: 150px;
    margin: 20px 30px 20px 0 !important;
    font-family: 'Hanken Grotesk Navs', sans-serif;
    font-size: 20px;
    font-weight: 600;
}

.donationForm .donate-button:hover, .donationForm #submitButton:hover {
    background: #3a4d6d;
    border-color: #3a4d6d;
}

.donationForm .row {
    display: block;
    width: 100%;
    clear: both;
    margin: 0;
}

.donationForm input, .donationForm textarea, .donationForm select, .inputFix {
    height: auto;
    display: inline-block;
    padding: 18.5px 14px;
    width: 95%;
    max-width: 480px;
    margin: 0 auto;
    background-color: transparent;
    border: 4px solid #58aede;
    color: #212121;
    font-size: 18px;
    font-weight: 500;
}

.donationForm input#GiftAid, .donationForm input#Fees, .donationForm input#Anon {
    margin: 0 6px 7px 0px;
    height: 15px;
    width: 27px;
}

.donationForm .shortfieldfirst {
    width: calc(50% - 40px) !important;
}

.donationForm .col-md-2 {
    float: left;
    width: 48%;
    padding: 0px 18px 11px 0;
}

.donationForm .radiogroup .col-md-2 {
    padding: 0px 18px 0px 0;
}

.donationForm .radiogroup {
    padding: 30px 0;
}

.donationForm .col-md-4 {
    float: left;
    width: 50%;
    padding: 0 20px 20px 0;
}

.donationForm img.DirectDebitLogo {
    margin: 0 0 10px 0;
    width: 150px;
    image-rendering: -moz-crisp-edges;
    image-rendering: -o-crisp-edges;
    image-rendering: -webkit-optimize-contrast;
    image-rendering: crisp-edges;
    -ms-interpolation-mode: nearest-neighbor;
}

.donationForm .radiogroup label.error {
    padding: 0 !important;
}

.donationForm label.error {
    border-color: #b94a48;
    box-shadow: none;
    color: #b94a48;
    padding: 8px 0 0;
    display: block;
}

.donationForm .error {
    box-shadow: none;
}

.donationForm label {
    padding: 5px 0;
    display: inline-block;
}

.donationForm .anongroup {
    text-align: left;
    margin-top: 10px;
}

.donationForm .anongroup label {
    padding-right: 25px;
}

.donationForm .commsgroup input[type=radio], .donationForm input[type=radio] {
    width: 15px;
    height: 15px;
    position: relative;
    top: 1px;
    margin: 0 7px;
}

.donationForm input[type="radio"] {
    -webkit-appearance: none;
    appearance: none;
    background-color: #f5f5f5;
    font: inherit;
    color: currentColor;
    width: 25px;
    height: 25px;
    border-radius: 50%;
    margin: 0 10px -5px 0;
    padding: 0;
    position: relative;
}

.donationForm input[type="radio"]::before {
    content: "";
    width: 9px;
    height: 9px;
    border-radius: 50%;
    transform: scale(0);
    background-color: #58aede;
    position: absolute;
    left: 4px;
    top: 4px;
}

.donationForm input[type="radio"]:checked::before {
    transform: scale(1);
}

.donationForm input[name="Email"] {
    margin-bottom: 20px;
}

.donationForm .commsgroup span {
    width: auto;
    margin: 0 12px 0 0;
    display: inline-block;
    color: #212121;
    min-width: 100px;
}

.donationForm .commsgroup .commsAlert {
    background: #26B3D5;
    color: #fff;
    border-radius: 12px;
    padding: 12px;
    font-size: 15px;
    line-height: 20px;
}

.donationForm .commsgroup div {
    display: flex;
}

.donationForm .commsgroup div input {
    width: 16px;
    margin: 0 20px 0 0;
    border: 4px solid #58aede !important;
    position: relative;
}

.donationForm input#GiftAid,
.donationForm input#Fees,
.donationForm input#Anon {
    position: relative;
}

.gagroup label {
    padding-left: 10px;
}

.donationForm .commsgroup div input:after {
    content: ' ';
    display: block;
    width: 16px;
    height: 16px;
    background-color: #f5f5f5;
    border: 4px solid #58aede;
    position: absolute;
    top: 6px;
    left: 0;
    cursor: pointer;
}

.donationForm input#GiftAid:after,
.donationForm input#Fees:after,
.donationForm input#Anon:after {
    content: ' ';
    display: block;
    width: 16px;
    height: 16px;
    background-color: #f5f5f5;
    border: 4px solid #58aede;
    position: absolute;
    top: -4px;
    left: 0;
    cursor: pointer;
}

.donationForm .commsgroup div input:checked:after,
.donationForm input#GiftAid:checked:after,
.donationForm input#Fees:checked:after,
.donationForm input#Anon:checked:after {
    content: "\4e";
    font-family: ETmodules !important;
    font-weight: 600 !important;
    color: #58aede;
    font-size: 16px;
}

.donationForm .newslettergroup input[type=radio] {
    width: 15px;
    height: 15px;
    position: relative;
    top: -1px;
    margin: 0 7px;
}

.donationForm .newslettergroup span {
    width: auto;
    margin: 0 12px 0 0;
    display: inline-block;
}

.donationForm .container.contact, .donationForm .container.payment {
    margin: 40px auto;
}

.donationForm .radiogroup input, .donationForm .taggroup input {
    margin: 0 12px 0 0;
    position: relative;
    top: -2px;
}

.donationForm .taggroup label {
    width: 100%;
    display: inline-block;
}

.donationForm .radiogroup span {
    margin: 0 12px 0 0;
}

.donationForm .container {
    width: 100% !important;
    overflow: hidden;
    padding: 0 !important;
}

.donationForm .inputFix {
    padding: 16px 12px 12px 12px;
}

.donationForm .container.giftaid, .donationForm .container.payment {
    border: 3px #000000 solid;
    padding: 15px;
    margin: 15px 0;
    line-height: 20px;
}

.donationForm img.giftAidLogo {
    width: 150px;
    margin: 0 40px 0 0;
    float: left;
    image-rendering: -moz-crisp-edges;
    image-rendering: -o-crisp-edges;
    image-rendering: -webkit-optimize-contrast;
    image-rendering: crisp-edges;
    -ms-interpolation-mode: nearest-neighbor;
}

.donationForm .gagroup {
    padding: 40px 0;
    color: #212121;
    position: relative;
}

.donationForm .container.consent, .donationForm .container.contact {
    padding: 36px 30px 20px 30px;
    border-radius: 50px;
    background: #ebebeb;
}

.donationForm small {
    padding: 0;
    display: block;
    font-size: 12px;
    line-height: 18px;
}

.donationForm .commsgroup {
    padding: 20px 0 0px;
    overflow: hidden;
}

.donationForm textarea {
    height: auto;
}

.donationForm section.contact-details p {
    margin: 10px 0 0 0;
}

.donationForm .buttonRow {
    text-align: center;
}

/* ==========================================================
   WOOCOMMERCE CHECKOUT
   ========================================================== */

#title_checkout_field > p {
    width: 100%;
    clear: both;
    display: block;
}

#title_checkout_field #title {
    background-color: #eee;
    width: 100%;
    max-width: 165px;
    border-width: 0;
    border-radius: 0;
    color: #999;
    font-size: 14px;
    padding: 16px;
    line-height: 1.7em;
    border-style: solid;
}

/* ==========================================================
   RESPONSIVE
   ========================================================== */

@media (max-width: 980px) {
    #donorfyDonation .controls ul li span, #donorfyDonation .donation-options .option p, #donorfyDonation #customAmount, #donorfyDonation #otherAmount label {
        font-size: calc(16px + 6 * ((40vw - 320px) / 680));
    }

    #donorfyDonation .controlsRow label {
        right: 6%;
    }

    #donorfyDonation #otherAmount {
        grid-column: 1/-1;
    }

    #donorfyDonation .donation-options {
        grid-template-columns: repeat(3, 1fr);
    }

    #donorfyDonation input#fundSelect {
        position: relative;
        top: 0;
        max-width: 100%;
    }

    #donorfyDonation #itemList {
        max-width: 100%;
    }

    #donorfyDonation #itemList.active, #donorfyDonation #targetFund.active, #donorfyDonation .controlsRow #customAmount.active {
        display: block;
        margin: 0;
        max-width: 100%;
    }

    #donorfyDonation.donorfyDonation-1col input#fundSelect {
        position: relative;
        left: 0;
        top: 0;
        margin-top: 20px;
        width: 100% !important;
        max-width: 100%;
    }

    #donorfyDonation #itemList {
        top: -31px;
        position: relative;
    }

    #donorfyDonation #targetFund {
        top: 0;
        position: relative;
        padding-bottom: 0;
    }

    #donorfyDonation.donorfyDonation-1col .controls {
        margin-top: 0px;
    }

    #donorfyDonation.donorfyDonation-1col {
        padding: 20px 30px;
    }
}

@media (max-width: 890px) {
    .donationForm {
        padding: 40px 0px 20px 0px;
        width: 95%;
    }

    .donationForm .col-md-4 {
        width: 100%;
        padding: 0 0 20px 0;
    }

    .donationForm input, .donationForm textarea, .donationForm select, .inputFix {
        width: 100%;
        max-width: unset;
    }

    .donationForm .expdate input, .donationForm .shortfield {
        width: 50% !important;
    }

    .donationForm img.DirectDebitLogo {
        margin: 40px 0 10px 0;
    }

    .donationForm img.giftAidLogo {
        position: absolute;
        top: 20px;
        width: 150px;
        margin: 0 30px 0 0;
    }

    .donationForm .gagroup label {
        margin: 60px 0 0 0;
    }

    .donationForm .payfields .row {
        padding: 0;
    }

    .donationForm .payfields {
        padding: 30px 0 0 0;
    }

    #donorfyDonation.donorfyresult .et_pb_button, #donorfyDonation .buttonRow {
        font-size: calc(16px + 6 * ((40vw - 320px) / 680));
    }

    #donorfyDonation .buttonRow {
        width: 50% !important;
    }

    #repGivingFormHeader {
        width: 100%;
        float: left;
        padding-right: 0;
    }

    #repGivingFormHeader h2 {
        margin-bottom: 0;
    }

    #repGivingFormIntro {
        width: 100%;
        float: left;
    }
}

@media (max-width: 650px) {
    #donorfyDonation .controlsRow label {
        position: static;
    }

    #donorfyDonation .donation-options {
        padding: 0 0 20px 0;
        grid-template-columns: repeat(3, 1fr);
    }

    #donorfyDonation .donationFrame, #donorfyDonation .controls {
        width: 100%;
    }

    #donorfyDonation.donorfyDonation-1col,
    #donorfyDonation.donorfyDonation-2col > div:nth-of-type(2) {
        padding: 20px 25px;
        width: 90%;
    }

    #donorfyDonation .controls ul li,
    #donorfyDonation .donation-options .option,
    #donorfyDonation .controlsRow,
    .donationForm input#GiftAid:after,
    .donationForm input#Fees:after,
    .donationForm input#Anon:after,
    .donationForm .commsgroup div input:after {
        border: 3px solid #58aede;
    }

    #donorfyDonation #otherAmount label {
        padding: 16px 15px !important;
    }

    #repGivingFormIntro {
        padding-left: 0;
    }

    .donationForm {
        width: 90%;
    }

    .donationForm .shortfieldfirst {
        width: 100% !important;
    }

    .donationForm form {
        padding: 25px;
    }
}

@media (max-width: 400px) {
    #donorfyDonation .donation-options {
        gap: 25px 3px;
    }

    #donorfyDonation .controls ul li {
        margin: 7px 0 0;
    }

    #donorfyDonation .controls ul {
        display: block;
    }
}
/*
 Theme Name:  Divi Child Theme
 Theme URI:  http://elegantthemes.com/
 Description: Divi Child Theme
 Author:    ElegantThemes
 Author URI:  http://elegantthemes.com
 Template:   Divi
 Version:   4.2.0
 License:   GNU General Public License v2 or later
 License URI: http://www.gnu.org/licenses/gpl-2.0.html
 Tags: responsive-layout, one-column, two-columns, three-columns, four-columns, left-sidebar, right-sidebar, custom-background, custom-colors, featured-images, full-width-template, post-formats, rtl-language-support, theme-options, threaded-comments, translation-ready
 Text Domain: divi-child-theme
*/

/* ==========================================================
   HANKEN GROTESK NAVS — SELF-HOSTED WEBFONTS
   ========================================================== */

@font-face {
  font-family: 'Hanken Grotesk Navs';
  src: url('/wp-content/themes/fonts/HankenGrotesk-Navs-Regular-fixed.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Hanken Grotesk Navs';
  src: url('/wp-content/themes/fonts/HankenGrotesk-Navs-Medium-fixed.woff2') format('woff2');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Hanken Grotesk Navs';
  src: url('/wp-content/themes/fonts/HankenGrotesk-Navs-SemiBold-fixed.woff2') format('woff2');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Hanken Grotesk Navs';
  src: url('/wp-content/themes/fonts/HankenGrotesk-Navs-Bold-fixed.woff2') format('woff2');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

/* ==========================================================
   GLOBAL TYPOGRAPHY SYSTEM
   Scoped for front-end content only
   ========================================================== */

:root {
  --brand-blue: #5aafe0;
  --h6-colour: #414644;
  --font-sans: 'Hanken Grotesk Navs', system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  --font-ivy: "ivypresto-display", serif;
}

/* Force Navs font across all elements, overriding any Divi inline font-family */
* {
  font-family: 'Hanken Grotesk Navs', system-ui, -apple-system, sans-serif !important;
}

/* Preserve Ivy Presto on H4 */
.et_pb_text h4,
.et_pb_blurb_content h4,
.et_pb_toggle_content h4,
.et_pb_tab h4,
.et_pb_accordion_item h4,
.et_pb_slide_description h4,
.et_pb_post h4,
.entry-content h4,
.et-l--body h4 {
  font-family: var(--font-ivy) !important;
}

/* =================================
   CONTENT WRAPPERS ONLY
   ================================= */

.et_pb_text,
.et_pb_blurb_content,
.et_pb_toggle_content,
.et_pb_tab,
.et_pb_accordion_item,
.et_pb_slide_description,
.et_pb_post,
.entry-content,
.et-l--body {
  font-family: var(--font-sans);
}

/* =================================
   HEADINGS BASE
   ================================= */

.et_pb_text h1,
.et_pb_text h2,
.et_pb_text h3,
.et_pb_text h4,
.et_pb_text h5,
.et_pb_blurb_content h1,
.et_pb_blurb_content h2,
.et_pb_blurb_content h3,
.et_pb_blurb_content h4,
.et_pb_blurb_content h5,
.et_pb_toggle_content h1,
.et_pb_toggle_content h2,
.et_pb_toggle_content h3,
.et_pb_toggle_content h4,
.et_pb_toggle_content h5,
.et_pb_tab h1,
.et_pb_tab h2,
.et_pb_tab h3,
.et_pb_tab h4,
.et_pb_tab h5,
.et_pb_accordion_item h1,
.et_pb_accordion_item h2,
.et_pb_accordion_item h3,
.et_pb_accordion_item h4,
.et_pb_accordion_item h5,
.et_pb_slide_description h1,
.et_pb_slide_description h2,
.et_pb_slide_description h3,
.et_pb_slide_description h4,
.et_pb_slide_description h5,
.et_pb_post h1,
.et_pb_post h2,
.et_pb_post h3,
.et_pb_post h4,
.et_pb_post h5,
.entry-content h1,
.entry-content h2,
.entry-content h3,
.entry-content h4,
.entry-content h5,
.et-l--body h1,
.et-l--body h2,
.et-l--body h3,
.et-l--body h4,
.et-l--body h5 {
  color: var(--brand-blue) !important;
  font-family: var(--font-sans) !important;
  font-weight: 600 !important;
  line-height: 1.1;
  margin: 0 0 0.6em 0;
  letter-spacing: -0.02em;
}

/* =================================
   H1
   ================================= */

.et_pb_text h1,
.et_pb_blurb_content h1,
.et_pb_toggle_content h1,
.et_pb_tab h1,
.et_pb_accordion_item h1,
.et_pb_slide_description h1,
.et_pb_post h1,
.entry-content h1,
.et-l--body h1 {
  font-size: clamp(3.4rem, 2.2rem + 4vw, 5.6rem) !important;
  font-weight: 700 !important;
  line-height: 1.03;
  letter-spacing: -0.03em;
}

/* =================================
   H2
   ================================= */

.et_pb_text h2,
.et_pb_blurb_content h2,
.et_pb_toggle_content h2,
.et_pb_tab h2,
.et_pb_accordion_item h2,
.et_pb_slide_description h2,
.et_pb_post h2,
.entry-content h2,
.et-l--body h2 {
  font-size: clamp(2.6rem, 1.9rem + 2.6vw, 3.8rem) !important;
  font-weight: 700 !important;
}

/* =================================
   H3
   ================================= */

.et_pb_text h3,
.et_pb_blurb_content h3,
.et_pb_toggle_content h3,
.et_pb_tab h3,
.et_pb_accordion_item h3,
.et_pb_slide_description h3,
.et_pb_post h3,
.entry-content h3,
.et-l--body h3 {
  font-size: clamp(2rem, 1.5rem + 1.9vw, 2.8rem) !important;
  font-weight: 600 !important;
}

/* =================================
   H4
   ================================= */

.et_pb_text h4,
.et_pb_blurb_content h4,
.et_pb_toggle_content h4,
.et_pb_tab h4,
.et_pb_accordion_item h4,
.et_pb_slide_description h4,
.et_pb_post h4,
.entry-content h4,
.et-l--body h4 {
  font-family: var(--font-ivy) !important;
  font-style: italic !important;
  font-weight: 400 !important;
  font-size: clamp(2.6rem, 1.9rem + 2.6vw, 3.8rem) !important;
  line-height: 1.1;
  letter-spacing: -0.01em;
}

/* =================================
   H5
   ================================= */

.et_pb_text h5,
.et_pb_blurb_content h5,
.et_pb_toggle_content h5,
.et_pb_tab h5,
.et_pb_accordion_item h5,
.et_pb_slide_description h5,
.et_pb_post h5,
.entry-content h5,
.et-l--body h5 {
  font-size: clamp(1.4rem, 1.2rem + 0.8vw, 1.8rem) !important;
  font-weight: 600 !important;
}

/* =================================
   H6
   ================================= */

.et_pb_text h6,
.et_pb_blurb_content h6,
.et_pb_toggle_content h6,
.et_pb_tab h6,
.et_pb_accordion_item h6,
.et_pb_slide_description h6,
.et_pb_post h6,
.entry-content h6,
.et-l--body h6 {
  color: var(--h6-colour) !important;
  font-family: var(--font-sans) !important;
  font-weight: 600 !important;
  font-size: clamp(1.15rem, 1rem + 0.5vw, 1.35rem) !important;
  letter-spacing: -0.01em;
}

/* =================================
   PARAGRAPHS
   ================================= */

.et_pb_text p,
.et_pb_blurb_content p,
.et_pb_toggle_content p,
.et_pb_tab p,
.et_pb_accordion_item p,
.et_pb_slide_description p,
.et_pb_post p,
.entry-content p,
.et-l--body p {
  font-family: var(--font-sans) !important;
  font-weight: 550 !important;
  line-height: 1.5;
  letter-spacing: -0.02em;
  margin-bottom: 1em;
}

/* =================================
   LISTS
   ================================= */

.et_pb_text ol,
.et_pb_text ul,
.et_pb_blurb_content ol,
.et_pb_blurb_content ul,
.et_pb_toggle_content ol,
.et_pb_toggle_content ul,
.et_pb_tab ol,
.et_pb_tab ul,
.et_pb_accordion_item ol,
.et_pb_accordion_item ul,
.et_pb_slide_description ol,
.et_pb_slide_description ul,
.et_pb_post ol,
.et_pb_post ul,
.entry-content ol,
.entry-content ul,
.et-l--body ol,
.et-l--body ul {
  list-style: none;
  font-family: var(--font-sans) !important;
  font-weight: 700 !important;
  padding-left: 0;
  margin-left: 0;
}

/* =================================
   HERO / LARGE HEADING UTILITIES
   ================================= */

.hero-heading h1 {
  font-size: clamp(4.5rem, 3rem + 5vw, 7.5rem) !important;
  line-height: 0.98 !important;
  letter-spacing: -0.035em !important;
}

.hero-heading h4 {
  font-size: clamp(4rem, 2.8rem + 4.5vw, 6.5rem) !important;
  line-height: 1 !important;
  letter-spacing: -0.02em !important;
}

.hero-heading h1,
.hero-heading h4 {
  margin-bottom: 0.3em !important;
}

/* =========================================
   WooCommerce product archive title fix
   ========================================= */

.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce-page ul.products li.product .woocommerce-loop-product__title,
.woocommerce .products ul li.product .woocommerce-loop-product__title,
.woocommerce-page .products ul li.product .woocommerce-loop-product__title {
  font-size: clamp(1.1rem, 0.95rem + 0.6vw, 1.6rem) !important;
  line-height: 1.2 !important;
  font-weight: 700 !important;
  margin: 12px 0 8px 0 !important;
  padding: 0 !important;
}

.woocommerce ul.products li.product .price,
.woocommerce-page ul.products li.product .price {
  font-size: 1rem !important;
  line-height: 1.3 !important;
  margin-top: 0 !important;
}

.woocommerce ul.products li.product .star-rating,
.woocommerce-page ul.products li.product .star-rating {
  font-size: 0.9rem !important;
  margin: 8px 0 6px 0 !important;
}

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  margin-bottom: 2.5em !important;
}

/* =========================================
   WooCommerce Order Confirmation Message
   ========================================= */

.woocommerce-notice.woocommerce-notice--success.woocommerce-thankyou-order-received {
  font-size: clamp(1.8rem, 1.4rem + 1.5vw, 2.6rem) !important;
  font-weight: 700 !important;
  color: #5aafe0 !important;
  line-height: 1.2 !important;
  margin-bottom: 1.2em !important;
  padding: 12px 16px !important;
  background: rgba(90, 175, 224, 0.08);
  border-left: 4px solid #5aafe0;
  border-radius: 4px;
}

/* ==========================================================
   NAV
   ========================================================== */

.nav > li > a {
    position: relative;
    display: block;
    padding: 0 15px;
}

.nav > li > a:hover, .nav > li > a:focus {
    background-color: unset;
}

#faqs .et_pb_blurb_content {
    max-width: unset;
}

/* ==========================================================
   GIVING / DONATION FORMS
   ========================================================== */

.giving-h4 h4 {
    font-family: 'Hanken Grotesk Navs', sans-serif;
    font-style: normal;
    font-size: 93px !important;
    font-weight: 500;
    letter-spacing: -0.25rem !important;
}

#repGivingFormHeader {
    width: 44%;
    float: left;
    padding-right: 40px;
}

#repGivingFormHeader h2 {
    font-size: 52px !important;
    line-height: 1.15 !important;
}

#repGivingFormIntro {
    width: 56%;
    float: left;
    padding-left: 20px;
}

#repGivingCode {
    clear: both;
}

section.content-section.gfmessage { text-align: left; background: #58aede; display: block; padding: 1px 24px 24px 24px; margin: 0 0 30px 0; color: #ffffff; }
section.content-section.gfmessage h3, section.content-section.gfmessage p { background: #58aede; color: #ffffff; }

#donorfyDonation {
    max-width: 1280px;
    padding-bottom: 80px;
}

#donorfyDonation.donorfyDonation-1col {
    max-width: 810px;
}

#donorfyDonation.donorfyDonation-2col > div:nth-of-type(2),
#donorfyDonation.donorfyDonation-1col {
    border-radius: 0;
    padding: 20px 50px 20px 50px;
    margin: 0 auto 85px auto;
    text-align: center;
    border: 4px solid #58aede;
}

#donorfyDonation #widgetID {
    display: none;
}

#donorfyDonation h2 {
    text-align: center;
    font-weight: 600;
    line-height: 1.2;
    text-align: left;
    letter-spacing: -0.075rem;
    margin: 0 0 40px 0;
    padding: 0;
    font-size: 46px;
}

#donorfyDonation h3 {
    font-size: 38px;
    font-weight: 600;
    letter-spacing: -0.075rem;
    margin-bottom: 12px;
}

#donorfyDonation p {
    text-align: left;
    color: #58aede;
    letter-spacing: -0.03rem;
    font-size: 23px;
    max-width: 600px;
    font-weight: 500;
    line-height: 1.35;
}

#donorfyDonation #repGivingFormIntro p {
    font-size: 18px;
    color: #231f20;
    letter-spacing: 0;
}

#donorfyDonation .et_pb_column .et_pb_text {
    margin: 0 0 20px;
}

#donorfyDonation #itemList.active, #donorfyDonation #targetFund.active, #donorfyDonation .controlsRow #customAmount.active {
    display: inline-block;
}

#donorfyDonation .controlsRow #customAmount {
    display: none;
}

#donorfyDonation #itemList li {
    list-style-type: none;
    cursor: pointer;
    font-size: 16px;
    font-family: 'Hanken Grotesk Navs', sans-serif;
    color: #231f20;
    padding: 2px 0;
}

#donorfyDonation #itemList li strong {
    font-weight: normal;
}

#donorfyDonation #itemList li.persist:nth-child(2) {
    padding-bottom: 10px;
    border-bottom: 1px dotted #58aede;
    margin: 0 0 10px 0;
}

#donorfyDonation #itemList li:hover {
    color: #58aede;
}

#donorfyDonation #itemList li.persist, #donorfyDonation .donationFrame.active {
    display: block !important;
}

#donorfyDonation #itemList, #targetFund, #donorfyDonation #oneoffTemp, #donorfyDonation #monthlyTemp, #donorfyDonation .donationFrame {
    display: none;
}

#donorfyDonation #targetFund {
    clear: both;
    width: 100%;
    text-align: left;
    max-width: 100%;
    padding: 25px 0 25px 30px;
    font-size: 18px;
    color: #231f20;
    position: absolute;
    left: 0;
    top: -35px;
    font-family: 'Hanken Grotesk Navs', sans-serif;
}

#donorfyDonation #targetFund:before {
    content: "\4e";
    background: #58aede;
    font-family: ETmodules !important;
    font-weight: 400 !important;
    color: #ffffff;
    border-radius: 100%;
    height: 30px;
    width: 30px;
    padding: 4px 4px 2px 2px;
    margin: 0px 10px 0 -30px;
}

#donorfyDonation.donorfyDonation-1col input#fundSelect {
    display: inline-block;
    background-color: transparent;
    padding: 18.5px 14px;
    width: 100%;
    max-width: 300px;
    border: 4px solid #58aede;
    font-family: 'Hanken Grotesk Navs', sans-serif !important;
    font-weight: 500;
    font-size: 18px;
    margin-right: 100%;
    position: absolute;
    left: 0;
    top: -95px;
}

#donorfyDonation.donorfyDonation-1col .controls {
    margin-top: -40px;
}

#donorfyDonation input#fundSelect:focus,
#donorfyDonation input#fundSelect:active {
    background-color: #58aede20 !important;
}

#donorfyDonation input#fundSelect::placeholder {
    font-family: 'Hanken Grotesk Navs', sans-serif !important;
    font-size: 18px;
    color: #231F20;
    font-weight: 500;
}

#donorfyDonation #itemList {
    overflow-y: scroll;
    background-color: #f5f5f5;
    max-height: 298px;
    width: 100%;
    max-width: 300px;
    margin: 0 auto;
    text-align: left;
    border: 4px solid #58aede;
    padding: 10px;
    position: absolute;
    top: -31px;
    left: 0;
    scrollbar-color: #58aede transparent;
    scrollbar-width: thin;
    margin-right: 100%;
}

#donorfyDonation #itemList::-webkit-scrollbar {
    width: 14px;
}

#donorfyDonation #itemList::-webkit-scrollbar-track {
    background: transparent;
}

#donorfyDonation #itemList::-webkit-scrollbar-thumb {
    background-color: #58aede80;
    border-radius: 20px;
    border: 4px solid #f5f5f5;
}

#donorfyDonation .controls {
    padding: 0 0 20px 0;
    width: 100%;
    margin: 0 auto;
}

#donorfyDonation .controls ul {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 25px 12px;
    padding: 0;
    margin: 0;
}

#donorfyDonation .controls ul li, #donorfyDonation .donation-options .option {
    list-style-type: none;
    padding: 14px 14px;
    border: 4px solid #58aede;
    cursor: pointer;
    flex-direction: column;
    cursor: pointer;
    display: flex;
    justify-content: center;
    text-align: left;
    font-family: 'Hanken Grotesk Navs', sans-serif;
}

#donorfyDonation .controls ul li:hover, #donorfyDonation .donation-options .option:hover {
    background: #f5f5f5;
    color: #ffffff;
}

#donorfyDonation .controls ul li span, #donorfyDonation .donation-options .option p {
    color: #58aede;
    font-size: 20px;
    text-align: left;
    font-weight: 600;
}

#donorfyDonation .controls ul li.active, #donorfyDonation .donation-options .option.active {
    background: #58aede;
}

#donorfyDonation .controls ul li.active span, #donorfyDonation .donation-options .option.active p {
    color: #ffffff;
}

#donorfyDonation .donation-options {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 25px 12px;
    padding: 0;
    margin: 0 auto;
}

#donorfyDonation .donationFrame {
    width: 100%;
    margin: 0 auto;
}

#donorfyDonation .controlsRow {
    color: #58aede;
    font-weight: 600;
    cursor: pointer;
    font-family: 'Hanken Grotesk Navs', sans-serif;
    font-size: 20px;
    border: 4px solid #58aede;
    flex-direction: column;
    justify-content: center !important;
    display: flex;
    letter-spacing: -0.03rem;
}

#donorfyDonation .donation-options.conceal, #donorfyDonation .controlsRow label.conceal {
    display: none;
}

#donorfyDonation .controlsRow ul li {
    list-style-type: none;
    text-align: left;
    line-height: 1;
}

#donorfyDonation .controlsRow ul {
    padding: 0 0 0 0;
}

#donorfyDonation #customAmount {
    display: inline-block;
    padding: 14px 14px;
    width: 100%;
    max-width: 480px;
    margin: 0 auto;
    border: none;
    font-family: 'Hanken Grotesk Navs', sans-serif;
    font-weight: 600;
    font-size: 20px;
    color: #58aede;
}

#donorfyDonation #otherAmount label {
    padding: 18.5px 5px 18.5px 14px;
    display: block;
    font-size: 18px;
}

#donorfyDonation #otherAmount label.conceal {
    display: none;
}

#donorfyDonation #customAmount.active {
    background-color: #58aede20 !important;
}

#donorfyDonation #customAmount::placeholder {
    color: #58aede;
}

#donorfyDonation .buttonRow {
    list-style-type: none;
    padding: 14px;
    color: #ffffff;
    background: #58aede;
    border: 2px solid #58aede;
    cursor: pointer;
    width: calc(25% - 10px);
    float: right;
    margin: 20px 0 20px 0;
    font-family: 'Hanken Grotesk Navs', sans-serif;
    font-size: 20px;
    font-weight: 600;
    text-align: left;
}

#donorfyDonation .buttonRow:hover {
    background: #58aede;
    color: #ffffff;
    border: 2px solid #58aede;
}

#donorfyDonation.donorfyresult .et_pb_button:after {
    content: "";
}

#donorfyDonation.donorfyresult .et_pb_button {
    list-style-type: none;
    padding: 14px 9px 14px 0;
    color: #ffffff;
    background: #58aede;
    border: 2px solid #58aede;
    cursor: pointer;
    width: auto;
    margin: 20px 30px 20px 0 !important;
    font-family: 'Hanken Grotesk Navs', sans-serif;
    font-size: 20px;
    font-weight: 600;
    letter-spacing: 0;
}

#donorfyDonation.donorfyresult .et_pb_button:hover {
    background: #58aede;
    color: #ffffff !important;
    border: 2px solid #58aede;
}

#donorfyDonation.donorfyresult .et_pb_social_network_link a.icon {
    border-radius: 25px 25px 25px 25px !important;
}

#donorfyDonation small {
    display: none;
    max-width: 400px;
    text-align: left;
    position: relative;
    top: -33px;
    font-family: 'Hanken Grotesk Navs', sans-serif;
    font-size: 14px;
    font-weight: 400;
    line-height: 20px;
}

#donorfyDonation small.active {
    display: inline-block;
}

small#note::before {
    content: "i";
    background: #3a4d6d;
    font-weight: 400 !important;
    color: #ffffff;
    border-radius: 100%;
    height: 19px;
    width: 19px;
    padding: 0px 0 0 0;
    margin: 0px 10px 0 -30px;
    display: inline-block;
    text-align: center;
}

.donationForm {
    background-color: transparent;
    padding: 40px 10px 20px 20px;
    margin: 54px auto 85px auto;
    width: 90%;
    max-width: 900px;
    border: 4px solid #58aede;
    text-align: center;
    font-family: 'Hanken Grotesk Navs', sans-serif;
}

.donationForm section .row {
    overflow: hidden;
    padding-bottom: 0;
}

.donationForm section {
    position: relative;
}

.donationForm section.bill {
    margin: 0;
}

.donationForm section.bill .row {
    padding: 0;
}

.donationForm form {
    padding: 0 30px 0 30px;
}

.donationForm strong {
    color: #58aede;
    font-size: 18px;
}

.donationForm .col-md-6, .donationForm .col-md-4, .donationForm .col-md-12 {
    padding: 0 0 20px 0;
    text-align: left;
}

.donationForm h3 {
    font-size: 24px;
    font-weight: 600;
    padding: 10px 0;
    margin-top: 30px;
    letter-spacing: -0.04rem;
    color: #58aede;
}

.donationForm p, .donationForm label, .donationForm i, .donationForm .radiogroup span {
    color: #212121;
    font-size: 18px;
    text-align: left;
    font-weight: 500;
}

.donationForm #bill {
    width: 100%;
    margin: 30px 0 30px 0;
    border-radius: 15px;
    text-align: left;
}

.donationForm #bill p {
    font-size: 26px;
    line-height: 1.2;
    font-weight: 600;
}

.donationForm #bill .minor {
    color: #58aede;
}

.donationForm #bill .minor a {
    text-decoration: underline;
}

.donationForm .donate-button, .donationForm #submitButton {
    list-style-type: none;
    padding: 14px 9px 14px 0;
    color: #ffffff;
    background: #58aede;
    border: 2px solid #58aede;
    cursor: pointer;
    width: 150px;
    margin: 20px 30px 20px 0 !important;
    font-family: 'Hanken Grotesk Navs', sans-serif;
    font-size: 20px;
    font-weight: 600;
}

.donationForm .donate-button:hover, .donationForm #submitButton:hover {
    background: #3a4d6d;
    border-color: #3a4d6d;
}

.donationForm .row {
    display: block;
    width: 100%;
    clear: both;
    margin: 0;
}

.donationForm input, .donationForm textarea, .donationForm select, .inputFix {
    height: auto;
    display: inline-block;
    padding: 18.5px 14px;
    width: 95%;
    max-width: 480px;
    margin: 0 auto;
    background-color: transparent;
    border: 4px solid #58aede;
    color: #212121;
    font-size: 18px;
    font-weight: 500;
}

.donationForm input#GiftAid, .donationForm input#Fees, .donationForm input#Anon {
    margin: 0 6px 7px 0px;
    height: 15px;
    width: 27px;
}

.donationForm .shortfieldfirst {
    width: calc(50% - 40px) !important;
}

.donationForm .col-md-2 {
    float: left;
    width: 48%;
    padding: 0px 18px 11px 0;
}

.donationForm .radiogroup .col-md-2 {
    padding: 0px 18px 0px 0;
}

.donationForm .radiogroup {
    padding: 30px 0;
}

.donationForm .col-md-4 {
    float: left;
    width: 50%;
    padding: 0 20px 20px 0;
}

.donationForm img.DirectDebitLogo {
    margin: 0 0 10px 0;
    width: 150px;
    image-rendering: -moz-crisp-edges;
    image-rendering: -o-crisp-edges;
    image-rendering: -webkit-optimize-contrast;
    image-rendering: crisp-edges;
    -ms-interpolation-mode: nearest-neighbor;
}

.donationForm .radiogroup label.error {
    padding: 0 !important;
}

.donationForm label.error {
    border-color: #b94a48;
    box-shadow: none;
    color: #b94a48;
    padding: 8px 0 0;
    display: block;
}

.donationForm .error {
    box-shadow: none;
}

.donationForm label {
    padding: 5px 0;
    display: inline-block;
}

.donationForm .anongroup {
    text-align: left;
    margin-top: 10px;
}

.donationForm .anongroup label {
    padding-right: 25px;
}

.donationForm .commsgroup input[type=radio], .donationForm input[type=radio] {
    width: 15px;
    height: 15px;
    position: relative;
    top: 1px;
    margin: 0 7px;
}

.donationForm input[type="radio"] {
    -webkit-appearance: none;
    appearance: none;
    background-color: #f5f5f5;
    font: inherit;
    color: currentColor;
    width: 25px;
    height: 25px;
    border-radius: 50%;
    margin: 0 10px -5px 0;
    padding: 0;
    position: relative;
}

.donationForm input[type="radio"]::before {
    content: "";
    width: 9px;
    height: 9px;
    border-radius: 50%;
    transform: scale(0);
    background-color: #58aede;
    position: absolute;
    left: 4px;
    top: 4px;
}

.donationForm input[type="radio"]:checked::before {
    transform: scale(1);
}

.donationForm input[name="Email"] {
    margin-bottom: 20px;
}

.donationForm .commsgroup span {
    width: auto;
    margin: 0 12px 0 0;
    display: inline-block;
    color: #212121;
    min-width: 100px;
}

.donationForm .commsgroup .commsAlert {
    background: #26B3D5;
    color: #fff;
    border-radius: 12px;
    padding: 12px;
    font-size: 15px;
    line-height: 20px;
}

.donationForm .commsgroup div {
    display: flex;
}

.donationForm .commsgroup div input {
    width: 16px;
    margin: 0 20px 0 0;
    border: 4px solid #58aede !important;
    position: relative;
}

.donationForm input#GiftAid,
.donationForm input#Fees,
.donationForm input#Anon {
    position: relative;
}

.gagroup label {
    padding-left: 10px;
}

.donationForm .commsgroup div input:after {
    content: ' ';
    display: block;
    width: 16px;
    height: 16px;
    background-color: #f5f5f5;
    border: 4px solid #58aede;
    position: absolute;
    top: 6px;
    left: 0;
    cursor: pointer;
}

.donationForm input#GiftAid:after,
.donationForm input#Fees:after,
.donationForm input#Anon:after {
    content: ' ';
    display: block;
    width: 16px;
    height: 16px;
    background-color: #f5f5f5;
    border: 4px solid #58aede;
    position: absolute;
    top: -4px;
    left: 0;
    cursor: pointer;
}

.donationForm .commsgroup div input:checked:after,
.donationForm input#GiftAid:checked:after,
.donationForm input#Fees:checked:after,
.donationForm input#Anon:checked:after {
    content: "\4e";
    font-family: ETmodules !important;
    font-weight: 600 !important;
    color: #58aede;
    font-size: 16px;
}

.donationForm .newslettergroup input[type=radio] {
    width: 15px;
    height: 15px;
    position: relative;
    top: -1px;
    margin: 0 7px;
}

.donationForm .newslettergroup span {
    width: auto;
    margin: 0 12px 0 0;
    display: inline-block;
}

.donationForm .container.contact, .donationForm .container.payment {
    margin: 40px auto;
}

.donationForm .radiogroup input, .donationForm .taggroup input {
    margin: 0 12px 0 0;
    position: relative;
    top: -2px;
}

.donationForm .taggroup label {
    width: 100%;
    display: inline-block;
}

.donationForm .radiogroup span {
    margin: 0 12px 0 0;
}

.donationForm .container {
    width: 100% !important;
    overflow: hidden;
    padding: 0 !important;
}

.donationForm .inputFix {
    padding: 16px 12px 12px 12px;
}

.donationForm .container.giftaid, .donationForm .container.payment {
    border: 3px #000000 solid;
    padding: 15px;
    margin: 15px 0;
    line-height: 20px;
}

.donationForm img.giftAidLogo {
    width: 150px;
    margin: 0 40px 0 0;
    float: left;
    image-rendering: -moz-crisp-edges;
    image-rendering: -o-crisp-edges;
    image-rendering: -webkit-optimize-contrast;
    image-rendering: crisp-edges;
    -ms-interpolation-mode: nearest-neighbor;
}

.donationForm .gagroup {
    padding: 40px 0;
    color: #212121;
    position: relative;
}

.donationForm .container.consent, .donationForm .container.contact {
    padding: 36px 30px 20px 30px;
    border-radius: 50px;
    background: #ebebeb;
}

.donationForm small {
    padding: 0;
    display: block;
    font-size: 12px;
    line-height: 18px;
}

.donationForm .commsgroup {
    padding: 20px 0 0px;
    overflow: hidden;
}

.donationForm textarea {
    height: auto;
}

.donationForm section.contact-details p {
    margin: 10px 0 0 0;
}

.donationForm .buttonRow {
    text-align: center;
}

/* ==========================================================
   WOOCOMMERCE CHECKOUT
   ========================================================== */

#title_checkout_field > p {
    width: 100%;
    clear: both;
    display: block;
}

#title_checkout_field #title {
    background-color: #eee;
    width: 100%;
    max-width: 165px;
    border-width: 0;
    border-radius: 0;
    color: #999;
    font-size: 14px;
    padding: 16px;
    line-height: 1.7em;
    border-style: solid;
}

/* ==========================================================
   RESPONSIVE
   ========================================================== */

@media (max-width: 980px) {
    #donorfyDonation .controls ul li span, #donorfyDonation .donation-options .option p, #donorfyDonation #customAmount, #donorfyDonation #otherAmount label {
        font-size: calc(16px + 6 * ((40vw - 320px) / 680));
    }

    #donorfyDonation .controlsRow label {
        right: 6%;
    }

    #donorfyDonation #otherAmount {
        grid-column: 1/-1;
    }

    #donorfyDonation .donation-options {
        grid-template-columns: repeat(3, 1fr);
    }

    #donorfyDonation input#fundSelect {
        position: relative;
        top: 0;
        max-width: 100%;
    }

    #donorfyDonation #itemList {
        max-width: 100%;
    }

    #donorfyDonation #itemList.active, #donorfyDonation #targetFund.active, #donorfyDonation .controlsRow #customAmount.active {
        display: block;
        margin: 0;
        max-width: 100%;
    }

    #donorfyDonation.donorfyDonation-1col input#fundSelect {
        position: relative;
        left: 0;
        top: 0;
        margin-top: 20px;
        width: 100% !important;
        max-width: 100%;
    }

    #donorfyDonation #itemList {
        top: -31px;
        position: relative;
    }

    #donorfyDonation #targetFund {
        top: 0;
        position: relative;
        padding-bottom: 0;
    }

    #donorfyDonation.donorfyDonation-1col .controls {
        margin-top: 0px;
    }

    #donorfyDonation.donorfyDonation-1col {
        padding: 20px 30px;
    }
}

@media (max-width: 890px) {
    .donationForm {
        padding: 40px 0px 20px 0px;
        width: 95%;
    }

    .donationForm .col-md-4 {
        width: 100%;
        padding: 0 0 20px 0;
    }

    .donationForm input, .donationForm textarea, .donationForm select, .inputFix {
        width: 100%;
        max-width: unset;
    }

    .donationForm .expdate input, .donationForm .shortfield {
        width: 50% !important;
    }

    .donationForm img.DirectDebitLogo {
        margin: 40px 0 10px 0;
    }

    .donationForm img.giftAidLogo {
        position: absolute;
        top: 20px;
        width: 150px;
        margin: 0 30px 0 0;
    }

    .donationForm .gagroup label {
        margin: 60px 0 0 0;
    }

    .donationForm .payfields .row {
        padding: 0;
    }

    .donationForm .payfields {
        padding: 30px 0 0 0;
    }

    #donorfyDonation.donorfyresult .et_pb_button, #donorfyDonation .buttonRow {
        font-size: calc(16px + 6 * ((40vw - 320px) / 680));
    }

    #donorfyDonation .buttonRow {
        width: 50% !important;
    }

    #repGivingFormHeader {
        width: 100%;
        float: left;
        padding-right: 0;
    }

    #repGivingFormHeader h2 {
        margin-bottom: 0;
    }

    #repGivingFormIntro {
        width: 100%;
        float: left;
    }
}

@media (max-width: 650px) {
    #donorfyDonation .controlsRow label {
        position: static;
    }

    #donorfyDonation .donation-options {
        padding: 0 0 20px 0;
        grid-template-columns: repeat(3, 1fr);
    }

    #donorfyDonation .donationFrame, #donorfyDonation .controls {
        width: 100%;
    }

    #donorfyDonation.donorfyDonation-1col,
    #donorfyDonation.donorfyDonation-2col > div:nth-of-type(2) {
        padding: 20px 25px;
        width: 90%;
    }

    #donorfyDonation .controls ul li,
    #donorfyDonation .donation-options .option,
    #donorfyDonation .controlsRow,
    .donationForm input#GiftAid:after,
    .donationForm input#Fees:after,
    .donationForm input#Anon:after,
    .donationForm .commsgroup div input:after {
        border: 3px solid #58aede;
    }

    #donorfyDonation #otherAmount label {
        padding: 16px 15px !important;
    }

    #repGivingFormIntro {
        padding-left: 0;
    }

    .donationForm {
        width: 90%;
    }

    .donationForm .shortfieldfirst {
        width: 100% !important;
    }

    .donationForm form {
        padding: 25px;
    }
}

@media (max-width: 400px) {
    #donorfyDonation .donation-options {
        gap: 25px 3px;
    }

    #donorfyDonation .controls ul li {
        margin: 7px 0 0;
    }

    #donorfyDonation .controls ul {
        display: block;
    }
}