/*
 Theme Name:   GeneratePress Child
 Theme URI:    https://generatepress.com
 Description:  Default GeneratePress child theme
 Author:       Tom Usborne
 Author URI:   https://tomusborne.com
 Template:     generatepress
 Version:      0.1
*/

/*** Fonts ***/
/* Variable */
@font-face {
	font-family: "Manrope";
	font-display: swap;
	src:
		url("fonts/Manrope/Manrope-VariableFont.woff2") format("woff2-variations"),
		url("fonts/Manrope/Manrope-VariableFont.woff") format("woff"),
		url("fonts/Manrope/Manrope-VariableFont.ttf") format("truetype");
}

/* Weight 300 */
@font-face {
	font-family: "GothicA1-Thin";
	font-display: swap;
	src: 
		url("fonts/Gothic_A1/GothicA1-Thin.woff2") format("woff2"),
		url("fonts/Gothic_A1/GothicA1-Thin.woff") format("woff"),
		url("fonts/Gothic_A1/GothicA1-Thin.ttf") format("truetype");
}

/* Weight 400 */
@font-face {
	font-family: "GothicA1";
	font-display: swap;
	src: 
		url("fonts/Gothic_A1/GothicA1-Regular.woff2") format("woff2"),
		url("fonts/Gothic_A1/GothicA1-Regular.woff") format("woff"),
		url("fonts/Gothic_A1/GothicA1-Regular.ttf") format("truetype");
}

/* Weight 600 */
@font-face {
	font-family: "GothicA1-SemiBold";
	font-display: swap;
	src:
		url("fonts/Gothic_A1/GothicA1-SemiBold.woff2") format("woff2"),
		url("fonts/Gothic_A1/GothicA1-SemiBold.woff") format("woff"),
		url("fonts/Gothic_A1/GothicA1-SemiBold.ttf") format("truetype");
}

/* Weight 700 */
@font-face {
	font-family: "GothicA1-Bold";
	font-display: swap;
	src: 
		url("fonts/Gothic_A1/GothicA1-Bold.woff2") format("woff2"),
		url("fonts/Gothic_A1/GothicA1-Bold.woff") format("woff"),
		url("fonts/Gothic_A1/GothicA1-Bold.ttf") format("truetype");
}

/* Weight 800 */
@font-face {
	font-family: "GothicA1-ExtraBold";
	font-display: swap;
	src:
		url("fonts/Gothic_A1/GothicA1-ExtraBold.woff2") format("woff2"),
		url("fonts/Gothic_A1/GothicA1-ExtraBold.woff") format("woff"),
		url("fonts/Gothic_A1/GothicA1-ExtraBold.ttf") format("truetype");
}

/* Weight 900 */
@font-face {
	font-family: "GothicA1-Black";
	font-display: swap;
	src: 
		url("fonts/Gothic_A1/GothicA1-Black.woff2") format("woff2"),
		url("fonts/Gothic_A1/GothicA1-Black.woff") format("woff"),
		url("fonts/Gothic_A1/GothicA1-Black.ttf") format("truetype");
}

/*** Globals ***/
:root {
	/* Fonts */
	--Manrope: "Manrope";
	--Gothic: "GothicA1";
	--Gothic-Thin: "GothicA1-Thin";
	--Gothic-Black: "GothicA1-Black";
	--Gothic-Bold: "GothicA1-Bold";
	--Gothic-SemiBold: "GothicA1-SemiBold";
	--Gothic-ExtraBold: "GothicA1-ExtraBold";

	/* Colors */
	--red: #da2424;
	--white: #fff;
	--desmos-white: #fffafa;

	/* Font Weights */
	--light-weight: 300;
	--regular-weight: 400;
	--semibold-weight: 600;
	--bold-weight: 700;
	--extra-bold-weight: 800;

	/* Font Sizes */
	--generic-font: 20px;
	--h2-size: 40px;
	--h3-size: 35px;

	/* Line Heights */
	--generic-height: normal;

	/* Font Styles */
	--generic-style: normal;
}

/*** Site ***/
html {
	margin-top: 0 !important;
	scroll-behavior: smooth;
}

.site-content {
	padding: 0 !important;
}

.inside-footer-widgets {
	margin-left: 0 !important;
}

.inner-padding {
	padding: 0 !important;
}

.footer-widgets-container {
	padding: 0;
}

/* h2 {
	margin-top: 60px 
} */

::-webkit-scrollbar {
    display: none;
}

/*** Common ***/
/* Meet btn */
.meet-btn {
	display: inline-flex;
	align-items: center;
	transition: transform 0.3s ease-in-out;
	font-family: var(--Manrope);
}

.meet-btn::before {
	content: "";
	background-image: url("/wp-content/uploads/2025/09/arrow-red.svg");
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;

	height: 10px;
	width: 0;
	margin-left: 0;
	opacity: 0;
	position: relative;
	top: 2px;
	transition:
		width 0.3s ease-in-out,
		margin-left 0.3s ease-in-out,
		opacity 0.3s ease-in-out;
}

.meet-btn:hover {
	transform: translateX(10px);
}

.meet-btn:hover::before {
	width: 24px;
	margin-left: 10px;
	opacity: 1;
}

/* Offset scroll for anchor sections */
.dn-offset-scroll {
  scroll-margin-top: 150px;
}

.dn-offset-scroll:target {
  scroll-margin-top: 150px;
}
/* 
 * May use in future
 * 
.tailored-project h1 {
		margin-top: 60px;
		margin-bottom: 60px;
}

@media screen and (max-width: 768px) {
	.tailored-project h1 {
		margin-top: 30px;
		margin-bottom: 30px;
	}
} */

.single-post h2 {
	margin-top: 60px;
	margin-bottom: 60px;
}

@media screen and (max-width: 768px) {
	.single-post h2 {
		margin-top: 30px;
		margin-bottom: 30px;
	}
}

/* News posts & Tailored projects */
.tailored-project .wp-block-post-date,
.tailored-project .dn-diamond-item-alt,
.type-post .wp-block-post-date,
.type-post .dn-diamond-item-alt{
	font-size: 20px;
	font-family: Manrope;
}

@media screen and (max-width: 768px) {
	.dn-tailored-grid img {
		height: 50vw;
	}
}

.dn-tailored-grid-alt img:first-child {
    grid-column: span 2;
	max-height: 400px;
}

.dn-tailored-grid-alt img:not(:first-child) {
    width: 100%;
	height: 100%;
	max-height: 360px;
}


@media screen and (max-width: 768px) {
	.dn-tailored-grid-alt img:first-child  {
		max-height: 360px;
	}
	
	.dn-tailored-grid-alt img:not(:first-child){
	    max-height: 250px;
	}
}

/*** Header ***/
.site-header {
	background: transparent;
	position: fixed;
	left: 50%;
	transform: translate(-50%);
	z-index: 100;
	width: 100%;
}

.inside-header {
	border-radius: 50px;
	background: rgba(255, 255, 255, 0.91);
	margin: 20px 30px;
	filter: drop-shadow(0 4px 4px rgba(0, 0, 0, 0.25));
	backdrop-filter: blur(4.849999904632568px);
	padding: 0 50px 0 60px !important;
	transition: padding 0.75s ease-in-out;
}

.grid-container {
	max-width: unset !important;
}

/* @media screen and (max-width: 1320px){
	.grid-container {
		margin: 0;
	}
} */

.nav-float-right #site-navigation {
	margin-right: auto;
	background-color: transparent;
}

/* For English lower the padding */
html[lang="en-US"] .main-navigation .main-nav ul ul li a {
        line-height: normal;
        padding: 10px 5px;
}

.main-navigation .main-nav > ul {
	flex-wrap: unset;
}

.main-navigation .main-nav ul li a {
	text-transform: uppercase;
	font-family: var(--Manrope);
	font-weight: var(--regular-weight);
	font-size: var(--generic-font);
	line-height: var(--generic-height);

	padding-left: 0.42vw;
	padding-right: 0.42vw;
	
	transition: font-size 0.75s ease-in-out, 
                line-height 0.75s ease-in-out, 
                padding 0.75s ease-in-out;
    
    will-change: font-size, line-height;
}

@media screen and (min-width: 1440px) {
	.main-navigation .main-nav ul li a {
		padding-left: 1.042vw;
		padding-right: 1.042vw;
	}
}

.menu-item-has-children .dropdown-menu-toggle {
	padding-right: 0;
	padding-left: 5px !important;
}

/* Ivory search */
.dn-ivory-search {
	top: 4px;
}

.dn-ivory-search path.search-icon-path {
	fill: none !important;
}

/* Overlay */
#is-popup-wrapper {
	background: rgba(4, 4, 4, .85);
}

/* Form */
.is-popup-search-form form {
	display: flex;
    justify-content: center;
}

.is-form-style.is-form-style-3 label {
	width: calc(50%) !important;
}

.is-popup-search-form form input#is-search-input-0 {
    font-family: var(--Manrope);
    font-size: 18px !important;
    font-style: normal;
    line-height: 28px;
    border-top-left-radius: 10px;
    border-bottom-left-radius: 10px;
    background: #fffafa;
    width: 100%;
    height: 60px;
    margin-bottom: 20px;
	padding: 0 20px;
}

/* Search button */
.is-search-icon {
    width: 60px;
    height: 60px;
    display: flex !important;
    align-items: center;
    justify-content: center;
    padding-top: 0 !important;
    border-bottom-right-radius: 10px;
	border-top-right-radius: 10px;
	background: var(--red);
	border: 0;
}

.is-search-icon:hover{
	background: var(--red);
}

.is-search-icon path {
	fill: var(--white) !important;
}

/* Close button top right */
.popup-search-close::before,
.popup-search-close::after {
	border-color: var(--white) !important;
}



/* Scroll animations */
header.site-header {
	max-width: 100%;
	top: 0;
	z-index: 10000;
	transition: all 0.75s ease, width 0.75s ease-in-out; 
}

.site-logo {
	transition: all 0.75s ease-in-out; 
}

.site-logo img.header-image {
	transition: height 0.75s ease-in-out, width 0.75s ease-in-out; 
}

header.site-header .inside-header{
	padding: 16px 68px 16px 95px;
}

header.site-header.scrolled .site-logo img.header-image {
	width: 194px; 
}

header.site-header.scrolled {
	width: 1666px;
}

.main-navigation .main-nav ul li a {
	transition: font-size 0.75s ease-in-out;
	padding: 5px 20px !important;
}

header.site-header.scrolled .main-navigation .main-nav ul li a {
	font-size: 18px;
}

header.site-header .inside-header{
	transition:all 0.3s ease-in-out!important; 
}
	 

@media screen and (max-width: 768px) {
	header.site-header.scrolled .site-logo img.header-image {
		width: 100%; 
	}
}

/* Mobile menu */
.main-navigation .menu-toggle {
	background: transparent !important;
	padding: 0;
}

.gp-icon .icon-menu-bars-open,
.gp-icon .icon-menu-bars-close {
	width: 20px;
	height: 20px;
}

.menu-toggle {
	line-height: unset;
}

.gp-icon .icon-menu-bars-close {
	display: none;
}

.has-inline-mobile-toggle #site-navigation.toggled {
	background-color: transparent;
	display: flex;
	font-size: var(--generic-font-size);
	justify-content: center;
}

/* .has-inline-mobile-toggle #site-navigation.toggled .main-navigation .main-nav .desmos-submenu a {
	font-size: var(--generic-font-size) !important;
} */

.has-inline-mobile-toggle .mobile-menu-control-wrapper,
.has-inline-mobile-toggle #site-navigation.toggled
.has-inline-mobile-toggle .mobile-menu-control-wrapper {
	background: transparent;
	margin-left: 0;
}

/* Place the X better */
.icon-menu-bars-close {
	position: relative;
	top: 5px;
	right: 5px;
}

.has-inline-mobile-toggle .mobile-menu-control-wrapper.toggled {
	margin-left: auto !important;
}

@media screen and (max-width: 1320px) {
	.site-header.toggled {
        border-radius: 15px !important;
    }
	
	.site-header .inside-header {
		display: flex;
		justify-content: space-between;
/* 		padding: 16px 30px 16px 20px !important; */
		padding: 10px 30px 10px 20px !important;
	}
	
	.site-header .inside-header .header-image {
		scale: 0.85;
	}
	
	.main-navigation.toggled .main-nav {
		max-height: 80vh;
    	overflow-y: auto;
	}

	.main-navigation .main-nav ul {
		flex-direction: column;
        justify-content: center;
	}
	
	.main-navigation .main-nav ul li a {
		font-size: 18px;
		text-align: center;	
		padding: 5px 0;
	}
	
	.has-inline-mobile-toggle .header-widget {
		flex-basis: unset;
		order: -1;
	}
	
	.has-inline-mobile-toggle .header-widget .search-icon {
		display: none;
	}

	.site-header .header-widget {
		order: -1;
		max-width: max-content;
		margin-top: 0;
		margin-left: 0;
		margin-right: 0;
	}

	.search-icon {
		display: none;
	}

	.site-header .header-widget .wp-block-search {
		display: none;
	}

	.site-header .main-navigation.toggled + .header-widget {
		display: block;
		margin-top: 1em !important;
		margin-bottom: 2em !important;
		display: flex;
		justify-content: center;
		order: 2;
		margin-left: auto;
		margin-right: auto;
	}

	.inside-header:has(.main-navigation.toggled) .site-logo {
		display: none;
	}
	
	.main-navigation.toggled .menu-item-has-children .dropdown-menu-toggle {
		float: unset !important;
	}
}

@media screen and (max-width: 500px) {
	.site-header .inside-header .site-logo {
		scale: 0.7;
	}

	.site-header .inside-header {
		padding-right: 20px !important;
		padding-left: 20px !important;
		margin: 20px;
		justify-content: space-around;
	}

	.menu-toggle {
		height: 20px;
	}
}


/* News menu item */
.news-menu {
	position: relative;
	top: 0.47px;
}

/* Submenus */
/* Desmos submenu */
.desmos-menu {
	padding-top: 35px;
	padding-bottom: 35px;
}

@media screen and (max-width: 1320px) {
	.desmos-menu {
		padding-top: 0;
		padding-bottom: 0;
	}
}

.desmos-menu ul {
	top: 95px !important;
	max-width: 68vw;
	width: 100vw !important;
	position: absolute !important; 
	left: -13vw !important;
/* 	min-height: 371px;  */
	min-height: 200px;
    display: grid !important; 
    grid-template-columns: 33% 33% 2% 31%; 
	grid-template-rows: min-content min-content min-content 1fr; 
    padding: 30px; 
    align-items: start; 
    gap: 15px 10px; 
	border-radius: 20px;
	backdrop-filter: blur(8.300000190734863px);
}

@media screen and (max-width: 1440px) {
	.desmos-menu ul {
		max-width: unset;
		width: calc(100vw - 200px) !important;
    	position: absolute !important;
    	left: -18vw !important;
	}
}

.desmos-menu ul::before {
	content: "";
	position: absolute;
	bottom: 100%;
	left: 25%;
	transform: translateX(-50%);
	width: 20px;
	height: 10px;
	background-color: rgba(255, 250, 250, 0.95);
	backdrop-filter: blur(8.300000190734863px);
	clip-path: polygon(50% 0%, 0% 110%, 100% 110%);
}

.desmos-menu ul li {
    list-style: none; 
    padding: 5px 0;
    margin: 0;
}

/* Column 1, Row 1 */
.desmos-menu ul li:nth-child(1) {
    grid-column: 1 / 2; 
    grid-row: 1 / 2; 
}

/* Column 1, Row 2 */
.desmos-menu ul li:nth-child(2) {
    grid-column: 1 / 2; 
    grid-row: 2 / 3; 
}

/* Column 1, Row 3 */
.desmos-menu ul li:nth-child(3) {
    grid-column: 1 / 2; 
    grid-row: 3 / 4; 
}

/* Column 2, Row 1 */
.desmos-menu ul li:nth-child(4) {
    grid-column: 2 / 3; 
    grid-row: 1 / 5;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}



/* Font */
.main-navigation .main-nav .desmos-submenu a{
	font-weight: var(--bold-weight);
	font-size: 20px;
}

/* If the link is a page add the arrow */
.desmos-menu ul li:not(.menu-item-has-children) a::after {
    content: "";
    display: inline-block;
	position: relative;
	bottom: 2px;
    width: 8px; 
    height: 12px; 
    margin-left: 8px; 
    background-image: url("/wp-content/uploads/2025/11/gray-arrow-right.svg");
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    vertical-align: middle; 
}

/* If the link is a submenu */

/* Remove the default toggle */
.desmos-submenu .dropdown-menu-toggle {
	display: none;
}

/* Style the submenu */
.desmos-submenu > .sub-menu {
    display: block !important;
    opacity: 1 !important;
	position: static !important; 
    width: auto !important;
    height: auto !important;
    overflow: visible !important;
    background-color: transparent !important;
    box-shadow: none !important; 
    backdrop-filter: none !important;
    transform: none !important;
	margin-left: 30px;
    margin-top: 15px;
    padding: 0 !important;
}

/* Remove inherited content */
.desmos-submenu ul::before,
.desmos-submenu ul::after {
	display: none;
}

/* Style the inner links */
.desmos-submenu ul li {
    grid-column: auto !important; 
    grid-row: auto !important;
    display: block !important; 
    padding: 5px 0 !important;
    margin: 0 !important;
}

.desmos-submenu ul li a {
    font-size: 18px !important; 
    font-weight: var(--regular-weight) !important; 
}

.desmos-submenu ul li:not(.menu-item-has-children) a::after {
    content: "";
    display: inline-block;
    position: relative;
    bottom: 2px;
    width: 8px; 
    height: 12px; 
    margin-left: 8px; 
    background-image: url("/wp-content/uploads/2025/11/gray-arrow-right.svg");
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    vertical-align: middle; 
}

/* Line */
.desmos-menu ul::after { 
    content: "";
    position: absolute; 
    top: 30px;
    bottom: 30px; /* ensures full height */
    left: 66%;
    width: 2px;
    background-color: var(--red);
}

/* Column 4 — image section */
.desmos-menu:hover::after {
    content: "";
    position: absolute;
    top: 140px;
    height: 250px;
    bottom: 30px;
    max-width: 17vw !important;
    width: 100vw !important;
    right: 30px;
    left: calc(33vw);
    background-image: url(/wp-content/uploads/2025/09/beneficiaries.jpg);
    background-size: cover;
    background-position: center;
    border-radius: 15px;
	margin-left: 30px;
    z-index: 99999;
    opacity: 1;
}

@media screen and (max-width: 1440px) {
	.desmos-menu:hover::after {
		margin-left: 0;
		max-width: 24vw !important;
		left: calc(41vw);
	}	
}


@media screen and (max-width:1320px) {
	/* On mobile view place it below parent links */
	.desmos-menu ul {
		display: flex !important;
		flex-direction: column !important;
		position: relative !important;
		top: 0 !important;
		padding-top: 0 !important;
		padding-bottom: 0;
		width: 100% !important;
		min-height: 100%;
		backdrop-filter: unset !important;
		background-color: transparent !important;
		border-bottom: 0 !important;
		gap: 0px;
	}
	
	/* Hide after elements */
	.desmos-menu ul::after,	
	.desmos-menu:hover::after {
		display: none;
	}
	
	.desmos-submenu ul{
		visibility: visible !important;
		backdrop-filter: unset !important;
		background-color: transparent !important;
		border-bottom: 0 !important;
	}
	
	/* Align the item on center */
	.desmos-menu ul li:nth-child(4) {
		align-items: center;
	}

	.desmos-submenu > .sub-menu{
		margin-left: 0;
		margin-top: 0;
		width: 100%;
		pointer-events: all;
	}
	
	.main-navigation .main-nav .desmos-submenu a {
		font-size: 16px;
		padding: 0;
		font-weight: 500;
	}
	
}

/* Hidden by default */
.desmos-menu::after {
    content: "";
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease;
}



/* Our work submenu */
.work-menu {
	padding-top: 35px;
	padding-bottom: 35px;
}

@media screen and (max-width: 1320px) {
	.work-menu {
		padding-top: 0;
		padding-bottom: 0;
	}
}

.work-menu ul {
	top: 95px !important;
	max-width: 88vw !important;
	width: 100vw !important;
	position: absolute !important; 
	left: -33vw !important;
    display: grid !important; 
	grid-template-columns: 365px 500px 10px 400px !important; 
/* 	grid-template-rows: min-content min-content min-content 1fr !important;
	 align-content: start !important;  */
	padding: 30px; 
    align-items: start; 
    gap: 5px 20px; 
	border-radius: 20px;
	backdrop-filter: blur(8.300000190734863px);
}

@media screen and (max-width: 1440px){
	.work-menu ul {
		width: calc(100vw - 60px) !important;
	}
}

.work-menu ul::before {
	content: "";
	position: absolute;
	bottom: 100%;
	left: 40%;
	transform: translateX(-50%);
	width: 20px;
	height: 10px;
	background-color: rgba(255, 250, 250, 0.95);
	backdrop-filter: blur(8.300000190734863px);
	clip-path: polygon(50% 0%, 0% 110%, 100% 110%);
}

.work-menu ul li {
    list-style: none; 
    padding: 2px 0;
    margin: 0;
}


/* Items in Column 1 (First 350px) */
.work-menu ul li:nth-child(1),
.work-menu ul li:nth-child(2),
.work-menu ul li:nth-child(5) {
    grid-column: 1 / 2; 
}

/* Items in Column 2 (Second 350px) */
.work-menu ul li:nth-child(3),
.work-menu ul li:nth-child(4),
.work-menu ul li:nth-child(6) {
    grid-column: 2 / 3; 
}

/* Column 2, Row 1 */
/* .work-menu ul li:nth-child(3) {
    grid-column: 2 / 3; 
    grid-row: 1 / 2; 
} */

/* Column 2, Row 2 */
/* .work-menu ul li:nth-child(4) {
    grid-column: 2 / 3; 
    grid-row: 2 / 3; 
} */

/* Column 3, Row 1 */
/* .work-menu ul li:nth-child(5) {
    grid-column: 1 / 2; 
    grid-row: 3 / 4; 
} */

/* Column 3, Row 2 */
/* .work-menu ul li:nth-child(6) {
    grid-column: 2 / 3; 
    grid-row: 3 / 4; 
} */

.work-menu ul li:nth-child(1) { grid-row: 1 / 2; }
.work-menu ul li:nth-child(2) { grid-row: 2 / 3; }
.work-menu ul li:nth-child(3) { grid-row: 1 / 2; }
.work-menu ul li:nth-child(4) { grid-row: 2 / 3; }
.work-menu ul li:nth-child(5) { grid-row: 3 / 4; }
.work-menu ul li:nth-child(6) { grid-row: 3 / 4; }

/* Font */
.main-navigation .main-nav .work-submenu a{
	font-weight: var(--bold-weight);
	font-size: 20px;
}

/* If the link is page add the arrow */
.work-menu ul li:not(.menu-item-has-children) a::after {
    content: "";
    display: inline-block;
	position: relative;
	bottom: 2px;
    width: 8px; 
    height: 12px; 
    margin-left: 8px; 
    background-image: url("/wp-content/uploads/2025/11/gray-arrow-right.svg");
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    vertical-align: middle; 
}

/* If the link is a submenu */

/* Remove the default toggle */
.work-submenu .dropdown-menu-toggle {
	display: none;
}

/* Style the submenu */
.work-submenu > .sub-menu {
    display: block !important;
    opacity: 1 !important;
    position: static !important; 
    width: auto !important;
    height: auto !important;
    overflow: visible !important;
    background-color: transparent !important;
    box-shadow: none !important; 
    backdrop-filter: none !important;
    transform: none !important;
	margin-left: 30px;
    margin-top: 15px;
    padding: 0 !important;
}

/* Remove inherited content */
.work-submenu ul::before,
.work-submenu ul::after {
	display: none;
}

/* Style the inner links */
.work-submenu ul li {
    grid-column: auto !important; 
    grid-row: auto !important;
    display: block !important; 
    padding: 5px 0 !important;
    margin: 0 !important;
}

.work-submenu ul li a {
    font-size: 18px !important; 
    font-weight: var(--regular-weight) !important; 
}

.work-submenu ul li:not(.menu-item-has-children) a::after {
    content: "";
    display: inline-block;
    position: relative;
    bottom: 2px;
    width: 8px; 
    height: 12px; 
    margin-left: 8px; 
    background-image: url("/wp-content/uploads/2025/11/gray-arrow-right.svg");
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    vertical-align: middle; 
}

/* Line */
.work-menu ul::after { 
    content: "";
    position: absolute; 
    top: 30px;
    bottom: 30px; 
    left: 60%; 
    width: 2px;
    background-color: var(--red);
}

/* Column 4 — image section */
.work-menu:hover::after {
    content: "";
    position: absolute;
    top: 140px;
    height: 320px;
    bottom: 30px;
	max-width: 26.95vw !important;
    width: 100vw !important;
    right: 30px;
    left: calc(22vw);
    background-image: url(/wp-content/uploads/2025/10/pronoia.jpg);
    background-size: cover;
    background-position: center;
    border-radius: 15px;
    z-index: 99999;
    opacity: 1;
}

/* Hidden by default */
.work-menu::after {
    content: "";
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease;
}

@media screen and (max-width: 1700px) and (min-width: 1442px) {
	.work-menu ul {
		grid-template-columns: 365px 370px 10px 400px !important; 
	}
}


@media screen and (max-width: 1441px) and (min-width: 1321px){
	.work-menu ul {
		max-width: 92vw !important;
		grid-template-columns: 365px 400px 10px 400px !important; 
		left: -36vw !important;
	}
		
	.work-menu ul::after {
		left: 68%;
	}
	
	.work-menu:hover::after {
		left: calc(28vw);
	}
}

@media screen and (max-width:1320px) {
	/* On mobile view place it below parent links */
	.work-menu ul {
		display: flex !important;
		flex-direction: column !important;
		position: relative !important;
		top: 0 !important;
		padding-top: 0 !important;
		padding-bottom: 0;
		width: 100% !important;
		min-height: 100% !important;
		backdrop-filter: unset !important;
		background-color: transparent !important;
		border-bottom: 0 !important;
		gap: 0 !important;
	}
	
	/* Hide after elements */
	.work-menu ul::after,	
	.work-menu:hover::after {
		display: none;
	}
	
	.work-submenu ul{
		visibility: visible !important;
		background-color: transparent !important;
		border-bottom: 0 !important;
		margin-left: 0 !important;
		margin-top: 0 !important;
		width: 100%;
	}
	
	.work-submenu > .sub-menu {
		pointer-events: all;
		width: 100% !important;
	}
	
	
	.main-navigation .main-nav .work-submenu a {
		font-size: 16px;
		padding: 0;
		font-weight: 500;
	}
	
	.main-navigation .main-nav .work-submenu .sub-menu li a {
		font-size: 14px !important;
	}
}

/* Support submenu */
.support-menu {
	padding-top: 35px;
	padding-bottom: 35px;
}

@media screen and (max-width: 1320px) {
	.support-menu {
		padding-top: 0;
		padding-bottom: 0;
	}
}

.support-menu ul {
	top: 95px !important;
	position: absolute !important;
    padding: 30px; 
    align-items: center; 
	border-radius: 20px;
	width: max-content !important;
	background-color: var(--red) !important;
	backdrop-filter: blur(8.300000190734863px);
}

@media screen and (max-width:1320px) {
	.support-menu ul {
		position: relative !important;
		top: 0 !important;
		padding-top: 0;
		padding-bottom: 0;
		width: 100% !important;
		backdrop-filter: unset !important;
		background-color: transparent !important;
		border-bottom: 0 !important;
	}
	
	.main-navigation .main-nav .support-submenu a{
		font-weight: var(--bold-weight);
		color: var(--red) !important;
		font-size: 20px;
	}

	.main-navigation .main-nav .support-submenu a:hover {
		color: var(--red) !important;
	}
	
	.main-navigation .main-nav .sub-menu .support-submenu a {
		padding: 5px 0;
		color:var(--red) !important;
		font-size: 16px !important;
		font-weight: normal;
	}
	
	.main-navigation .main-nav .sub-menu .support-submenu a:hover {
		color:var(--red) !important ;
	}
}

.support-menu ul::before {
	content: "";
	position: absolute;
	bottom: 100%;
	left: 25%;
	transform: translateX(-50%);
	width: 20px;
	height: 10px;
	background-color: var(--red);
	backdrop-filter: blur(8.300000190734863px);
	clip-path: polygon(50% 0%, 0% 110%, 100% 110%);
}

/* Font */
.main-navigation .main-nav .support-submenu a{
	font-weight: var(--bold-weight);
	color: var(--white) !important;
	font-size: 20px;
}

.main-navigation .main-nav .support-submenu a:hover {
	color: var(--white) !important;
}


/* Partnership submenu */
.partner-menu {
	padding-top: 35px;
	padding-bottom: 35px;
}

@media screen and (max-width: 1320px) {
	.partner-menu {
		padding-top: 0;
		padding-bottom: 0;
	}
}

.partner-menu ul {
	top: 95px !important;
	position: absolute !important;
    padding: 30px; 
    align-items: center; 
	border-radius: 20px;
	backdrop-filter: blur(8.300000190734863px);
}

@media screen and (max-width:1320px) {
	.partner-menu ul {
		position: relative !important;
		top: 0 !important;
		padding-top: 0;
		padding-bottom: 0;
		width: 100% !important;
		backdrop-filter: unset !important;
		background-color: transparent !important;
		border-bottom: 0 !important;
	}
	
	.main-navigation .main-nav .sub-menu .partner-submenu a {
		padding: 5px 0;
		font-size: 16px !important;
		font-weight: normal;
	}
}

.partner-menu ul::before {
	content: "";
	position: absolute;
	bottom: 100%;
	left: 25%;
	transform: translateX(-50%);
	width: 20px;
	height: 10px;
	background-color: rgba(255, 250, 250, 0.95);
	backdrop-filter: blur(8.300000190734863px);
	clip-path: polygon(50% 0%, 0% 110%, 100% 110%);
}

/* Font */
.main-navigation .main-nav .partner-submenu a{
	font-weight: var(--bold-weight);
	font-size: 20px;
}

/*** Floating button ***/
.donate-box {
	position: fixed;
	top: 145px;
	right: -4px;
	background-color: var(--red);
	border-top-left-radius: 50px;
	border-bottom-left-radius: 50px;
	cursor: pointer;
	width: 119px;
	height: 70px;
	overflow: hidden;
	z-index: 99;
	transition: width 0.4s ease-in-out;
	display: flex;
	align-items: center;
	padding-left: 30px;
	box-sizing: border-box;
	text-decoration: none;
	cursor: pointer;
}

.donate-box:hover,
.donate-box.initial-play {
	width: 287px;
}

.donate-box .static-icon,
.donate-box .lottie-icon {
	flex-shrink: 0;
	margin-right: 15px;
	width: 50px;
	height: 50px;
	transition: opacity 0.3s ease;
}

.donate-box .lottie-icon {
	display: none;
	opacity: 0;
}

.donate-box:hover .lottie-icon,
.donate-box.initial-play .lottie-icon {
	display: block;
	opacity: 1;
}

.donate-box:hover .static-icon,
.donate-box.initial-play .static-icon {
	display: none;
	opacity: 0;
}

.donate-box .extra-content {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	opacity: 0;
	transform: translateX(-20px);
	transition:
		opacity 0.3s ease-in-out,
		transform 0.4s ease-in-out;
	white-space: nowrap;
}

.donate-box:hover .extra-content,
.donate-box.initial-play .extra-content {
	opacity: 1;
	transform: translateX(0);
}

.donate-box .extra-content p {
	margin: 0 10px 0 0;
	font-size: 20px;
	color: white;
	font-family: var(--Gothic);
}

.donate-box .extra-content img {
	margin: 0;
}

@media screen and (max-width: 768px) {
	.donate-box {
		width: 60px;
		height: 50px;
		padding-left: 15px;
	}

	.donate-box:hover,
	.donate-box.initial-play{
		width: 180px;
	}

	.donate-box .extra-content p {
		font-size: 16px;
	}

	.donate-box .static-icon,
	.donate-box .lottie-icon {
		width: 24px;
		height: 24px;
		transition: opacity 0.3s ease;
	}

	.donate-box:hover .lottie-icon {
		display: block;
		opacity: 1;
	}

	.donate-box:hover .static-icon {
		display: none;
		opacity: 0;
	}
}

/*** Home ***/
/* First Slider */
.hero-slider .swiper-slide {
	position: relative;
	overflow: hidden;
}

.hero-slider .swiper-slide > img {
	margin: 0;
	width: 100%;
	height: 911px;
	object-fit: cover;
}

/* Excerpt Container */
.hero-slider .swiper-slide > .slide-content-box {
	position: absolute;
	left: 60px;
	top: 190px;
	z-index: 10;
	opacity: 0.8;
	width: 660px;
	height: 600px;
	background: white;
	box-sizing: border-box;
	display: flex;
	flex-direction: column;
	justify-content: center;
}

@media screen and (max-width: 767px) {
	.hero-slider .swiper-slide > .slide-content-box {
		justify-self: center;
		width: calc(95vw - 60px);
		max-height: 300px;
 		left: 35px; 
		top: 25%;
		padding-left: 40px;
		padding-top: 26px;
	}
}

.hero-slider-buttons .prev-btn a,
.hero-slider-buttons .next-btn a {
	background-color: transparent !important;
}

.hero-slider-buttons .prev-btn .wp-block-button__link,
.hero-slider-buttons .next-btn .wp-block-button__link {
	font-size: 0;
	line-height: 0;
	position: relative;
	padding: 0px;
}

.hero-slider-buttons
	.prev-btn
	.wp-block-button__link::before
	.hero-slider-buttons
	.next-btn
	.wp-block-button__link::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 24px;
	height: 24px;
}

.hero-slider-buttons .prev-btn .wp-block-button__link::before {
	content: url("/wp-content/uploads/2025/09/prev-arrow.svg");
}

.hero-slider-buttons .next-btn .wp-block-button__link::before {
	content: url("/wp-content/uploads/2025/09/next-arrow.svg");
}

.hero-slider-buttons {
	position: absolute;
	bottom: 42px;
	left: 72px;
	gap: 30px;
}

@media screen and (max-width: 768px) {
	.hero-slider-buttons {
		display: none !important;
	}
}

/* Hero pagination */
.hero-pagination .swiper-pagination-bullet {
	position: relative;
	width: 50px;
	height: 3px;
	background: rgba(255, 0, 0, 0.5);
	border-radius: 6.5px;
	overflow: hidden;
}

.hero-pagination .swiper-pagination-bullet::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	height: 100%;
	width: 100%;
	background: var(--red);
/* 	transform: scaleX(0); */
	transform-origin: left center;
	transition: none;
}

.hero-pagination .swiper-pagination-bullet-active::after {
	animation: fill-progress 7s linear forwards;
}

@keyframes fill-progress {
	from {
		transform: scaleX(0);
	}
	to {
		transform: scaleX(1);
	}
}

@media screen and (max-width: 768px) {
	.swiper-pagination {
		right: unset !important;
		width: unset;
		bottom: 20px;
	}
}

.gb-text-b6e50fa7 strong,
.gb-text-2a38d247 strong {
	font-weight: 250 !important;
}

.gb-element-5f4f0bc0 {
	transform: rotate(180deg);
}

/* 4 Cards */

@media screen and (max-width: 1440px) {
	.dn-pylon-grid {
		display: grid !important;
		grid-template-columns: 2fr 2fr;
		row-gap: 20px;
	}
	
	.dn-pylon-grid div {
		width: 100%;
	}
}

.pylon-inner-container {
	backdrop-filter: blur(2px);
}

@media screen and (max-width: 1880px) {
	
	.pylon-inner-container h2 {
		font-size: 16px;
	}
	
	.pylon-inner-container h2 + p {
		font-size: 15px;
	}

	.pylon-inner-container p {
		line-height: 1.5em;
	}
}

.pylon-inner-container a {
	position: absolute;
	bottom: 32px;
}

/* Impact section */
.impact-main-slider .swiper-slide {
	position: relative;
}

.impact-main-slider .swiper-slide h2,
.impact-main-slider .swiper-slide p {
	opacity: 0;
	z-index: 1;
	transition: opacity 0.3s ease;
}

.impact-main-slider .swiper-slide.swiper-slide-active h2,
.impact-main-slider .swiper-slide.swiper-slide-active p {
	opacity: 1;
	z-index: 2;
}

.impact-nav-slider .swiper-slide {
	margin: 0 !important;
}

.impact-nav-slider .swiper-slide.swiper-slide-thumb-active p,
.impact-nav-slider .swiper-slide.swiper-slide-thumb-active h2 {
	color: var(--red);
}

.impact-nav-slider .swiper-slide-thumb-active .progress-bar {
	animation: fill-progress 3s linear forwards;
}

.progress-bar {
	width: 0%;
	height: 100%;
	background-color: var(--red);
	border-radius: 2px;
}

.progress-bar-container {
	width: 100%;
	height: 2px;
	background: transparent; /* Keep the gray bar transparent on Desktop view */
	border-radius: 2px;
	margin-top: 10px;
	overflow: hidden;
}

@media screen and (max-width: 1025px) and (min-width: 769px) {
	.progress-bar-container {
		width: 350px;
	}
}

.impact-main-slider .impact-pagination {
	display: none;
}

.impact-pagination .swiper-pagination-bullet {
	position: relative;
	width: 50px;
	height: 3px;
	background: rgba(255, 0, 0, 0.5);
	border-radius: 6.5px;
	overflow: hidden;
}

.impact-pagination .swiper-pagination-bullet::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	height: 100%;
	width: 0;
	background: var(--red);
	transform-origin: left center;
	transition: none;
}

.impact-pagination .swiper-pagination-bullet-active::after {
	animation: fill-progress 3s linear forwards; 
}

.big-num-impact {
	display: none;
}

/* The bullets and the progress bar below the big nums on MOBILE view */
@media (max-width: 768px) {
	.impact-nav-slider {
		display: none !important;
	}

	.big-num-impact {
		display: block;
	}

	.impact-main-slider .impact-pagination {
		display: flex;
		justify-content: center;
		position: absolute;
	}

	.impact-pagination .swiper-pagination-bullet {
		width: 40px;
		height: 4px;
		border-radius: 2px;
		background-color: #d8d8d8;
		opacity: 1;
	}

	.big-num-bar-container {
		width: 100%;
		height: 3px;
		background-color: transparent; /* Keep the gray bar transparent on Mobile view */
		border-radius: 2px;
		margin: 15px auto 25px auto;
		overflow: hidden;
	}

	.big-num-progress-bar {
		width: 0;
		height: 100%;
		background-color: var(--red);
		border-radius: 2px;
		transition: width 3s ease-in-out;
	}

	.big-num-progress-bar.is-animating {
		width: 100%;
	}

	/* The More btn below the bullets */
	.gb-text-995242ec {
		display: none;
	}
}

@media screen and (max-width: 425px) {
	.big-num-bar-container {
		width: 217px;
	}

	/* The More btn below the bullets */
	.gb-text-995242ec {
		display: block;
	}
}

/* Animation */
@keyframes fill-progress {
	from {
		width: 0%;
	}
	to {
		width: 100%;
	}
}

/* Support section */
.support-card p,
.support-card a {
	transition: all 0.2s ease-in-out;
}

.support-card:hover a {
	background: white;
}

.support-card:hover p {
	color: white;
}

/* .support-card:hover img:first-of-type {
  filter: brightness(0) invert(1);
} */

/* .support-card:hover .support-arrow {
  background-image: url('/wp-content/uploads/2025/09/support_arrow-red.svg');
} */

/*** News section ***/

/* Swiper */
.post-swiper {
	position: relative;
	overflow: hidden;
}

.post-swiper .swiper-button-prev,
.post-swiper .swiper-button-next {
	font-size: 0;
	color: transparent;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 10;
	background-color: transparent;
	border: none;
	padding: 0;
	margin: 0;
	cursor: pointer;
	width: 44px;
	height: 44px;
	background-size: 28px 28px;
	background-position: center;
	background-repeat: no-repeat;
	transition: opacity 0.2s ease-in-out;
}

.post-swiper .prev-post a,
.post-swiper .next-post a {
	background: transparent !important;
}

.post-swiper .prev-post .wp-block-button__link,
.post-swiper .next-post .wp-block-button__link {
	font-size: 0;
	line-height: 0;
	position: relative;
	padding: 0px;
}

.news-swiper-buttons {
	position: absolute;
	right: 52px;
	bottom: 15px;
	gap: 20px;
}

.swiper-slide-prev {
	margin-right: 0;
}

.news-content-box .meet-btn::before {
	background-image: url("/wp-content/uploads/2025/09/arrow_black.svg");
}

@media screen and (max-width: 768px) {
	.news-content-box {
		position: relative;
	}
}

.post-swiper
	.prev-post
	.wp-block-button__link::before
	.post-swiper
	.next-post
	.wp-block-button__link::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 24px;
	height: 24px;
}
.post-swiper .prev-post .wp-block-button__link::before {
	content: url("/wp-content/uploads/2025/09/prev-arrow.svg");
}

.post-swiper .next-post .wp-block-button__link::before {
	content: url("/wp-content/uploads/2025/09/next-arrow.svg");
}

/* White container section */
.news-content-box {
	width: 37.448vw;
	height: 400px;
	padding: 40px;
	box-sizing: border-box;
	display: flex;
	flex-direction: column;
}

/*** Small deeds section ***/
/* Pagination */
.deed-pagination {
	display: none;
}

.deed-pagination .swiper-pagination-bullet {
	position: relative;
	width: 50px;
	height: 3px;
	background: rgba(255, 0, 0, 0.5);
	border-radius: 6.5px;
	overflow: hidden;
}

.deed-pagination .swiper-pagination-bullet::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	height: 100%;
	width: 100%;
	background: var(--red);
	transform-origin: left center;
	transition: none;
}


@media screen and (max-width: 768px) {
	.deed-pagination {
		display: flex;
		justify-content: center;
	}
}
/* Posts */
.gb-element-4ceea49a {
	font-family: var(--Manrope);
}

.gb-element-4ceea49a time::before {
	content: "";
	display: inline-block;
	width: 15px;
	height: 17px;
	background: url("/wp-content/uploads/2025/09/calendar.svg") no-repeat center;
	background-size: contain;
	margin-right: 14px;
	position: relative;
	top: 1.5px;
}

/*** Newsletter Container ***/

/* Input field */
.newsletter-input,
.newsletter-input input {
	max-width: 431px;
	align-self: center;
	margin-left: auto;
	margin-right: auto;
}

.newsletter-input input,
.newsletter-input input:focus,
.newsletter-input input:active {
	border: 0;
	background: transparent;
}

.newsletter-input input,
.newsletter-input input:focus,
.newsletter-input input:active {
	border-bottom: 2px solid #d9d9d9;
}

.newsletter-input input {
	font-family: var(--Manrope);
}

/* Button */
.newsletter-submit-wrapper {
    text-align: center;
    margin-top: 10px; 
}

.newsletter-submit-wrapper input[type="submit"] {
    background-color: transparent;
    border: none;
    border-bottom: 1px solid var(--red);
    border-radius: 0;
    cursor: pointer;
    
    font-family: var(--Manrope);
    color: var(--red);
    font-weight: 500;
    font-size: 16px;
    padding: 0 25px 2px 0; 
    
    background-image: url("/wp-content/uploads/2025/09/newsletter-arrow.svg");
    background-repeat: no-repeat;
    background-position: right center;
    background-size: 15px 10px;
    
    transition: all 0.3s ease-in-out;
}

.newsletter-submit-wrapper input[type="submit"]:hover {
    font-size: 18px;
    
    background-image: none; 
    padding-right: 0; 
}

.wpcf7-spinner {
    display: none; 
}

@media screen and (max-width: 500px) {
	.newsletter-input,
	.newsletter-input input {
		max-width: 250px !important;
	}
}


/*** Better Future Page ***/
/** Teens for teens **/
/* TFT Form Wrapper */
.dn-tft-form-wrapper {
    width: 100%;
    max-width: 900px;
    margin: 0 auto;
    font-family: inherit;
    box-sizing: border-box;
}

.dn-tft-row {
    display: flex;
    gap: 15px;
    margin-bottom: 15px;
    flex-wrap: wrap;
    align-items: center;
}

.dn-tft-col-half { 
	flex: 1; 
	min-width: 250px; 
}

.dn-tft-col-full { 
	flex: 0 0 100%; 
}

/* Fix for CF7 adding <br> tags */
.dn-tft-col br {
    display: none;
}

.dn-tft-col p {
	margin-bottom: 10px;
    margin-top: 0;
}

/* Inputs & Selects */
.dn-tft-form-wrapper input[type="text"],
.dn-tft-form-wrapper input[type="email"],
.dn-tft-form-wrapper input[type="tel"],
.dn-tft-form-wrapper select,
.dn-tft-form-wrapper textarea {
    width: 100%;
    padding: 15px 25px;
    border-radius: 50px;
    background-color: #ffffff;
    font-family: var(--Manrope);
    color: #666;
    font-size: 18px;
	border: 1px solid #f2f2f2;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
    box-sizing: border-box;
    transition: all 0.3s ease;
}

.dn-tft-form-wrapper textarea {
    border-radius: 25px;
    min-height: 120px;
    resize: none;
}

.dn-tft-form-wrapper select {
    appearance: none;
    -webkit-appearance: none;
    cursor: pointer;
    background-image: url('/wp-content/uploads/2025/11/caret-down.svg');
    background-repeat: no-repeat;
    background-position: right 15px center;
}

.dn-tft-field-label {
    display: block;
    font-family: var(--Manrope);
    font-size: 16px;
    font-weight: 600;
    color: #4b4b4b;
    margin-bottom: 10px;
	margin-left: 8px;
}

/* --- Radio Buttons Styling --- */
.dn-tft-radio-wrapper {
	height: 103px; /* As per your previous CSS */
}

.dn-tft-radio-wrapper p {
    display: flex;
	flex-direction: column;
    align-items: start;
    margin: 0;
    flex-wrap: wrap;
}

.dn-tft-radio-label {
    font-family: var(--Manrope);
    font-weight: 600;
    font-size: 16px;
    color: #4b4b4b;
	margin-left: 8px;
    margin-right: 15px;
	margin-bottom: 5px;
    white-space: nowrap;
}

.dn-tft-radio-wrapper .wpcf7-form-control-wrap {
    display: inline-flex !important;
    align-items: center;
    width: auto !important;
	margin-left: 10px;
    margin-top: 20px;
}

.dn-tft-radio-wrapper .wpcf7-radio {
    display: flex;
    align-items: center;
}

.dn-tft-radio-wrapper .wpcf7-list-item {
    margin: 0 15px 0 0;
    display: inline-flex;
    align-items: center;
}

.dn-tft-radio-wrapper .wpcf7-list-item label {
    display: flex;
    align-items: center;
    cursor: pointer;
}

.dn-tft-radio-wrapper .wpcf7-list-item-label {
    font-family: var(--Manrope);
    font-size: 16px;
    padding-left: 5px;
}

.dn-tft-radio-wrapper input[type="radio"] {
    appearance: none;
    -webkit-appearance: none;
    width: 16px;
    height: 16px;
    border: 1px solid #E76D6C;
    border-radius: 50%;
    margin: 0;
    cursor: pointer;
    position: relative;
    background: #fff;
    display: block;
}

.dn-tft-radio-wrapper input[type="radio"]:checked::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 10px;
    height: 10px;
    background-color: #E76D6C;
    border-radius: 50%;
    transform: translate(-50%, -50%);
}

@media screen and (max-width: 500px){
	.dn-tft-radio-wrapper p {
		flex-direction: column;
		align-items: start;		
	}
	
	.dn-tft-radio-wrapper .wpcf7-form-control-wrap  {
		margin-left: 8px;
		margin-top: 5px;
	}
}

/* --- File upload --- */
.dn-tft-upload-label {
    cursor: pointer;
    font-family: var(--Manrope);
	font-weight: 600;
    font-size: 16px;
	margin-left: 8px;
    color: #4d4d4d;
    display: block;
}

.dn-tft-file {
	margin-top: 10px;
	margin-left: 3px;
	font-family: var(--Manrope);
    display: block;
}


/* File Input Font */
.dn-tft-col .wpcf7 input[type="file"] {
	font-family: var(--Manrope);
	font-size: 16px;
}


/* --- Privacy Checkbox --- */
.dn-tft-checkbox-wrapper {
	font-family: var(--Manrope);
}

.dn-tft-checkbox-wrapper input[type="checkbox"] {
    width: 20px;
    height: 20px;
    appearance: none;
    -webkit-appearance: none;
    background-color: #fff;
    border: 1px solid #E76D6C;
    margin-right: 10px;
    cursor: pointer;
    vertical-align: middle;
}

.dn-tft-checkbox-wrapper input[type="checkbox"]:checked::after {
    content: '';
    display: block;
    width: 12px;
    height: 12px;
    background: #E76D6C;
    margin: 3px;
}

.dn-tft-checkbox-wrapper .wpcf7-list-item {
	margin: 0;
}

.dn-tft-checkbox-wrapper a{
	color: #E76D6C;
	text-decoration: none;
}

/* Submit Section */
.dn-tft-submit-btn-container {
	display: flex;
	justify-content: center;
}

.dn-tft-submit-btn {
    background-color: var(--red) !important;
    color: #fff;
    border: none;
    padding: 15px 50px;
    border-radius: 50px;
    font-family: var(--Manrope);
    font-weight: 600;
    font-size: 18px;
    cursor: pointer;
    transition: all 0.3s ease;
}

.dn-tft-submit-btn:hover {
    background-color: #ddd ;
}

/* Mobile Responsiveness */
@media screen and (max-width: 768px) {
    .dn-tft-row { 
		flex-direction: column; 
		align-items: stretch; 
	}
	
    .dn-tft-col-half, 
	.dn-tft-col-full {
		width: 100%; 
	}
    
	.dn-tft-radio-wrapper { 
        height: auto;
		flex-direction: column; 
		align-items: flex-start; 
		gap: 10px; 
        margin-bottom: 20px;
	}
}

/*** Healthcare page ***/
.dn-hospital-separator {
	margin: 20px 0;
	width: 100%;
}


/* Cutout */
.dn-alt-cutout {
	clip-path: polygon(35% 0%, 45% 10%, 100% 10%, 100% 100%, 0% 100%, 0% 0%);
}

/* Split the title */
.dn-split-title .dn-split-wrapper {
    display: flex;
    flex-direction: column;
	width: 100%;
	min-height: 27px; 
    position: relative;
}

.dn-split-title .dn-year {
    color: var(--red);
    font-weight: 700;
    font-size: 20px;
	font-family: var(--Manrope);
	line-height: 1.2;
	display: block;
	min-height: 1.2em; 
}

.dn-split-title .dn-title-part {
    color: #252525;
	margin-top: 20px;
	font-size: 20px;
	line-height: 1.3;
}

@media screen and (max-width: 500px) {
	.dn-split-title .dn-title-part {
		margin-top: 10px;
	}
}


.dn-split-title .dn-title-part a{
	text-decoration: none;
	color: black;
}

/* Keep excerpt as it is written */
.dn-keep-newlines {
	white-space: pre-line;
}

/* Smart hack to make the container an entire link */
.dn-stretch-link a::after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 1;
    cursor: pointer;
}

/*** Building a better future Page ***/
/** Common **/

/* Red diamonds on bullet points */
.dn-diamond-item::before {
	content: "\25C6";
	color: var(--red);
    display: inline-block;
    width: 24px;
    height: 24px;
    margin-right: 25px;
}

.dn-diamond-item-alt::before {
	content: "\25C6";
	color: var(--red);
    display: inline-block;	
	width: 16px;
    height: 16px;
    margin-right: 4px;
}

.dn-diamond-item-alt a {
	text-decoration: none;
	color: var(--red);
}

/* Hr separator */
.dn-crisis-separator {
	margin: 20px 0;
	background-color: #e76d6c;
    color: #e76d6c;
	height: 2px;
    width: 100%;
}



/*** News Page ***/
.dn-news-pagination .page-numbers {
	background: white;
	border-radius: 80px;
	font-size: 16px;
	border: 1px solid var(--red) !important;
	color: var(--red) !important;
	font-family: var(--Manrope);
	width: 38px;
	height: 38px;
	padding: 5px;
	display: flex;
	align-items: center;
	justify-content: center;
	transform: background 0.5s ease-in-out;
}

.dn-news-pagination .current {
	border: 1px solid var(--red) !important;
	background: var(--red) !important;
	color: white !important;
	transition: opacity 0.3s ease-in-out;
}

.dn-news-pagination .page-numbers:not(.current):hover {
	background: var(--red);
	color: white !important;
}

.dn-news-pagination:has(.page-numbers:not(.current):hover) .current {
    opacity: 0.75;
}

/*** Donation Page ***/
.dn-paypal-btn-once img:nth-of-type(2) {
    transition: all 0.3s ease-in-out;
}

.dn-paypal-btn-once:hover img:nth-of-type(2) {
    scale: 1.5;
}

.dn-every-btn-once img:nth-of-type(2) {
	transition: all 0.3s ease-in-out;
}

.dn-every-btn-once:hover img:nth-of-type(2) {
    scale: 1.25;
}

/* Tabs (buttons) */
.dn-tab-content-once,
.dn-tab-content-monthly {
        display: none;
		padding-bottom: 50px;
}

.dn-tab-trigger-once,
.dn-tab-trigger-monthly {
        cursor: pointer;
        transition: all 0.3s ease;
}
.dn-faded {
    opacity: 0.5; 
    transition: all 0.3s ease;
}

.dn-active-tab {
        background-color: var(--red) !important; 
        color: #ffffff !important;
}

/* Each payment method has to have the checkmark */
.dn-visa-btn-once, 
.dn-bank-btn-once,
.dn-visa-btn-monthly, 
.dn-bank-btn-monthly {
    position: relative; 
}

.dn-sub-active::after {
    content: '';
    position: absolute;
    right: 20px;
    top: 50%;
    transform: translateY(-50%);
    width: 24px;
    height: 24px;
    background-image: url('/wp-content/uploads/2025/11/checkmark.svg');
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    
	/* Pop Out */
    opacity: 0;
    transform: translateY(-50%) scale(0);
    
    /* In and Out */
    transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    pointer-events: none; 
}

.dn-sub-active::after {
    opacity: 1;
    transform: translateY(-50%) scale(1);
}

/* Title */
.dn-donation-title {
	margin-bottom: 40px;
	width: 100%;
	grid-column: 1 / -1;
	font-family: var(--Manrope);
	font-weight: 600;
	color: var(--red);
	font-size: 30px;
	text-align: center;
}


/* Animation for containers */
.dn-fade-in {
	animation: dnFadeIn 0.5s forwards;
}


@keyframes dnFadeIn {
        from { opacity: 0; transform: translateY(-5px); }
        to { opacity: 1; transform: translateY(0); }
}

/* Amount buttons selected */
.dn-amount-btn-selected {
    background-color: var(--red) !important;
    color: #ffffff !important; 
}

.dn-custom-input-wrap {
    position: relative; 
    display: inline-block;
    width: 100%;
    max-width: 160px; 
}

/* Symbol (€) */
.dn-custom-input-wrap::after {
    content: '\20AC';
    position: absolute;
    right: 20px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--red);
    font-family: var(--Manrope);
    font-size: 24px;
    pointer-events: none; 
}

/* Custom amount */
input.dn-custom-input {
    border: 1px solid var(--red);
    border-radius: 50px;
    padding: 10px 20px 10px 20px; 
    color: var(--red);
    font-family: var(--Manrope);
    font-size: 18px;
    text-align: center;
    background: transparent;
    height: auto;
}

.dn-custom-input::placeholder {
    color: rgba(211, 47, 47, 0.5);
    font-size: 18px;
}

/* Subcontainers for each payment */
[class*="dn-content-"] {
    display: none;
}

.dn-sub-active {
    background-color: rgba(231, 109, 108, 0.25) !important;
    border-color: rgba(231, 109, 108, 0.25) !important;
    transition: all 0.3s ease;
}


/* Donation contact form common styles */

.dn-donation-form-wrapper {
    width: 100%;
    max-width: 900px;
    margin: 0 auto;
    font-family: inherit;
    box-sizing: border-box;
}

.dn-donation-row {
    display: flex;
    gap: 15px;
    margin-bottom: 15px;
    flex-wrap: wrap;
}

.dn-donation-col {
    flex: 1;
    min-width: 200px;
}

.dn-donation-col-full {
    flex: 0 0 100%;
}

.dn-donation-col-half {
    flex: 1;
}

.dn-donation-col-third {
    flex: 1;
}

.dn-donation-col-third-alt {
	width: 33%;
	position: relative; 
}

.dn-donation-form-wrapper input[type="text"],
.dn-donation-form-wrapper input[type="email"],
.dn-donation-form-wrapper input[type="tel"],
.dn-donation-form-wrapper select{
    width: 100%;
    padding: 15px 25px;
    border-radius: 50px;
    border: 1px solid transparent;
    background-color: #ffffff;
    font-family: var(--Manrope);
    color: #666;
    font-size: 18px;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.02);
    box-sizing: border-box;
    transition: all 0.3s ease;
}

.dn-donation-form-wrapper input:focus,
.dn-donation-form-wrapper select:focus{
    outline: none;
    border-color: #ccc;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}

.dn-donation-col-third-alt select {
    border: 1px solid #E76D6C !important; 
	color: #E76D6C;
	font-family: var(--Manrope);
	font-size: 20px;
	font-weight: 600;
	background: transparent;
	background-image: url('/wp-content/uploads/2025/11/caret-down-salmon.svg') !important;
}

@media screen and (max-width: 768px) {
	.dn-donation-col-third-alt select {
		font-size: 20px;
	}
}

@media screen and (max-width: 500px) {
	.dn-donation-col-third-alt {
		width: 100%;
	}
}

.dn-donation-form-wrapper select {
    appearance: none; 
    -webkit-appearance: none;
    cursor: pointer;
    background-image: url('/wp-content/uploads/2025/11/caret-down.svg');
    background-repeat: no-repeat;
    background-position: right 15px center;
}

.dn-donation-form-wrapper p {
    margin-bottom: 0;
}

.dn-donation-checkbox-wrapper {
    margin-bottom: 5px;
}

.dn-donation-checkbox-wrapper label {
	font-size: 16px;
}

.dn-donation-checkbox-wrapper input[type="checkbox"] {
    width: 20px;
    height: 20px;
    appearance: none;
    -webkit-appearance: none;
    background-color: #fff;
    border: 1px solid #E76D6C;
    margin-right: 10px;
    position: relative;
    bottom: 3px;
    cursor: pointer;
    vertical-align: text-bottom;
    transition: all 0.2s ease;
}

.dn-donation-checkbox-wrapper input[type="checkbox"]:checked::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 12px;
    height: 12px;
    background-color: #E76D6C;
    transform: translate(-50%, -50%);
    border-radius: 1px;
}

.dn-donation-checkbox-wrapper input[type="checkbox"]:checked {
    border-color: #E76D6C;
    box-shadow: 0 1px 1px 0 rgba(211, 47, 47, 0.3), 0 0 0 1px rgba(211, 47, 47, 0.2);
}

.dn-donation-checkbox-wrapper span.wpcf7-list-item {
    margin: 0;
    color: #4b4b4b;
    font-size: 20px;
    font-family: var(--Manrope);
}

.dn-donation-checkbox-wrapper span.wpcf7-list-item-label {
	cursor: pointer;
}

.dn-donation-checkbox-wrapper a {
    text-decoration: underline;
	color: #4b4b4b;
}

.dn-donation-footer p {
    text-align: right;
    font-size: 14px;
    font-family: var(--Manrope);
    font-weight: 500;
    color: #4B4B4B;
    margin-top: -5px;
    margin-bottom: 20px;
}

.dn-donation-submit {
    background-color: #d32f2f;
    color: #fff;
    border: none;
    padding: 12px 40px;
    border-radius: 50px;
    font-size: 16px;
    cursor: pointer;
    transition: background 0.3s ease;
}

.dn-donation-submit:hover {
    background-color: #b71c1c;
}

.dn-donation-form-wrapper input::placeholder,
.dn-donation-form-wrapper textarea::placeholder {
    font-family: var(--Manrope);
    color: #7C7C7C;
    font-size: 18px;
    opacity: 1;
}

.dn-donation-form-wrapper input::-webkit-input-placeholder,
.dn-donation-form-wrapper textarea::-webkit-input-placeholder {
    font-family: var(--Manrope);
    color: #7C7C7C;
    font-size: 18px;
}

.dn-donation-form-wrapper input::-moz-placeholder,
.dn-donation-form-wrapper textarea::-moz-placeholder {
    font-family: var(--Manrope);
    color: #7C7C7C;
    font-size: 18px;
    opacity: 1;
}

.dn-donation-form-wrapper input:-ms-input-placeholder,
.dn-donation-form-wrapper textarea:-ms-input-placeholder {
    font-family: var(--Manrope);
    color: #7C7C7C;
    font-size: 18px;
}

@media (max-width: 768px) {
    .dn-donation-row {
        flex-direction: column;
    }
    .dn-donation-col {
        width: 100%;
    }
	
	.dn-donation-checkbox-wrapper span.wpcf7-list-item {
		font-size: 16px;
		bottom: 2px;
	}
	
	.dn-donation-footer p {
		text-align: center;
	}
	

}

/* Company Donation section */
.dn-donation-checkbox-wrapper span[data-name="company-toggle"] label {
    font-family: var(--Manrope);
	font-size: 20px;
	color: #E76D6C;
	cursor: pointer;
}

.dn-company-title {
	font-family: var(--Gothic-Bold);
	text-align: center;
	font-size: 25px;
}

/* Container */
/* .dn-company-donation {
	display: block;
} */

/* Label on purpose */
.dn-donation-field-label {
    display: block;
    font-family: var(--Manrope);
    font-size: 16px;
    color: #4b4b4b;
    margin-bottom: 10px;
    margin-left: 8px;
}

/* If amount > 1000 euros */
#dn-high-amount-wrapper {
	display: none;
}

.dn-high-amount-msg {
    font-size: 14px;
    color: #d32f2f; /* Red color to draw attention */
    font-family: var(--Manrope);
    margin-top: 5px;
    font-style: italic;
}

/* Submit section */
.dn-submit-wrapper {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5.20vw; 
    margin-top: 40px;
    margin-bottom: 20px;
    width: 100%;
}

.dn-submit-wrapper .wpcf7-spinner {
	display: none;
}

.dn-line {
    height: 2px;
    background-color: #F2C3C3; /* Light Pink/Red */
    flex-grow: 1; 
}

.dn-submit-btn {
    background-color: var(--red) !important;
    color: #ffffff;
    font-family: var(--Gothic-ExtraBold);
    font-size: 18px;
	line-height: 1.5em;
    padding: 12px 30px !important;
    border-radius: 50px;
    border: none;
    cursor: pointer;
    transition: all 0.3s ease;
    -webkit-appearance: none;
}

.dn-submit-btn-container p {
	margin-bottom: 0;
}

/* Bank donation boxes */

/* Bolder letters */
.dn-iban-text,
.dn-benef-text,
.dn-swift-text {
	color: #252525;
	font-family: var(--Manrope);
	font-size: 16px;
	font-style: normal;
	font-weight: 800;
	line-height: 1.5em;
}

/*** Privacy Policy Page ***/
.dn-privacy-list {
    font-size: 20px;
    font-family: var(--Manrope);
    list-style: none;
    padding-left: 0; 
}

.dn-privacy-list li {
    position: relative;
    padding-left: 35px; 
    margin-bottom: 10px; 
}

.dn-privacy-list li::before {
    content: "\2022"; 
    color: var(--red);
	font-size: 2em;
    position: absolute;
    left: 0;
	top: -18px;
}

/*** Volunteer Page ***/
/* Volunteer Form Wrapper */
.dn-volunteer-form-wrapper {
    width: 100%;
    max-width: 900px;
    margin: 0 auto;
    font-family: inherit;
    box-sizing: border-box;
}

.dn-volunteer-row {
    display: flex;
    gap: 15px;
    margin-bottom: 15px;
    flex-wrap: wrap;
    align-items: center;
}

.dn-volunteer-col-half { 
	flex: 1; 
	min-width: 250px; 
}

.dn-volunteer-col-full { 
	flex: 0 0 100%; 
}

.dn-volunteer-col p {
	margin-bottom: 10px;
}

/* Inputs & Selects - Similar to donation form */
.dn-volunteer-form-wrapper input[type="text"],
.dn-volunteer-form-wrapper input[type="email"],
.dn-volunteer-form-wrapper input[type="tel"],
.dn-volunteer-form-wrapper select,
.dn-volunteer-form-wrapper textarea {
    width: 100%;
    padding: 15px 25px;
    border-radius: 50px;
    background-color: #ffffff;
    font-family: var(--Manrope);
    color: #666;
    font-size: 18px;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.02);
    box-sizing: border-box;
    transition: all 0.3s ease;
}

.dn-volunteer-form-wrapper textarea {
    border-radius: 25px;
    min-height: 120px;
    resize: none;
}

.dn-volunteer-form-wrapper select {
    appearance: none;
    -webkit-appearance: none;
    cursor: pointer;
    background-image: url('/wp-content/uploads/2025/11/caret-down.svg');
    background-repeat: no-repeat;
    background-position: right 15px center;
}

.dn-volunteer-field-label {
    display: block;
    font-family: var(--Manrope);
    font-size: 16px;
    font-weight: 600;
    color: #4b4b4b;
    margin-bottom: 10px;
	margin-left: 8px;
}

/* --- Radio Buttons Styling --- */
.dn-volunteer-radio-wrapper {
	height: 103px;
}


.dn-volunteer-radio-wrapper p {
    display: flex;
	flex-direction: column;
    align-items: start;
    margin: 0;
    flex-wrap: wrap;
}

.dn-volunteer-radio-label {
    font-family: var(--Manrope);
    font-weight: 600;
    font-size: 16px;
    color: #4b4b4b;
	margin-left: 8px;
    margin-right: 15px;
	margin-bottom: 5px;
    white-space: nowrap;
}

.dn-volunteer-radio-wrapper .wpcf7-form-control-wrap {
    display: inline-flex !important;
    align-items: center;
    width: auto !important;
	margin-left: 10px;
    margin-top: 20px;
}

.dn-volunteer-radio-wrapper .wpcf7-radio {
    display: flex;
    align-items: center;
}

.dn-volunteer-radio-wrapper .wpcf7-list-item {
    margin: 0 15px 0 0;
    display: inline-flex;
    align-items: center;
}

.dn-volunteer-radio-wrapper .wpcf7-list-item label {
    display: flex;
    align-items: center;
    cursor: pointer;
}

.dn-volunteer-radio-wrapper .wpcf7-list-item-label {
    font-family: var(--Manrope);
    font-size: 16px;
    padding-left: 5px;
}

.dn-volunteer-radio-wrapper input[type="radio"] {
    appearance: none;
    -webkit-appearance: none;
    width: 16px;
    height: 16px;
    border: 1px solid #E76D6C;
    border-radius: 50%;
    margin: 0;
    cursor: pointer;
    position: relative;
    background: #fff;
    display: block;
}

.dn-volunteer-radio-wrapper input[type="radio"]:checked::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 10px;
    height: 10px;
    background-color: #E76D6C;
    border-radius: 50%;
    transform: translate(-50%, -50%);
}

@media screen and (max-width: 500px){
	.dn-volunteer-radio-wrapper p {
		flex-direction: column;
		align-items: start;		
	}
	
	.dn-volunteer-radio-wrapper .wpcf7-form-control-wrap  {
		margin-left: 8px;
		margin-top: 5px;
	}
}

/* --- File upload --- */
.dn-volunteer-upload-label {
    cursor: pointer;
    font-family: var(--Manrope);
	font-weight: 600;
    font-size: 16px;
	margin-left: 8px;
    color: #4d4d4d;
}

.dn-volunteer-file {
	margin-top: 10px;
	margin-left: 3px;
	font-family: var(--Manrope);
}


/* Button  */
.dn-volunteer-col .wpcf7 input[type="file"] {
	font-family: var(--Manrope);
	font-size: 16px;
}


/* --- Privacy Checkbox --- */
.dn-volunteer-checkbox-wrapper {
	font-family: var(--Manrope);
	font-size: 16px;
}

.dn-volunteer-checkbox-wrapper input[type="checkbox"] {
    width: 20px;
    height: 20px;
    appearance: none;
    -webkit-appearance: none;
    background-color: #fff;
    border: 1px solid #E76D6C;
    margin-right: 10px;
    cursor: pointer;
    vertical-align: middle;
}

.dn-volunteer-checkbox-wrapper input[type="checkbox"]:checked::after {
    content: '';
    display: block;
    width: 12px;
    height: 12px;
    background: #E76D6C;
    margin: 3px;
}

.dn-volunteer-checkbox-wrapper .wpcf7-list-item {
	margin: 0;
}

.dn-volunteer-checkbox-wrapper a{
    text-decoration: underline;
	color: #4b4b4b;
}

/* Submit Section */
.dn-volunteer-submit-btn-container {
	display: flex;
	justify-content: center;
}

.dn-volunteer-submit-btn {
    background-color: var(--red) !important;
    color: #fff;
    border: none;
    padding: 15px 50px;
    border-radius: 50px;
    font-family: var(--Manrope);
    font-weight: 600;
    font-size: 18px;
    cursor: pointer;
    transition: all 0.3s ease;
}

.dn-volunteer-submit-btn:hover {
    background-color: #ddd ;
}

/* Mobile Responsiveness */
@media screen and (max-width: 768px) {
    .dn-volunteer-row { 
		flex-direction: column; 
		align-items: stretch; 
	}
	
    .dn-volunteer-col-half, 
	.dn-volunteer-col-full {
		width: 100%; 
	}
    
	.dn-volunteer-radio-wrapper { 
		flex-direction: column; 
		align-items: flex-start; 
		gap: 10px; 
	}
}

/*** Contact Form which is used in a lot of pages ***/
/* Contact form */
.dn-contact-form-title {
	display: flex;
	align-items: center;
	justify-content: center;
}

.dn-contact-form-title h2 {
	font-family: var(--Manrope);
	font-size: 32px;
	font-weight: 600;
	margin-bottom: 15px;
}

/* 1. General Wrapper */
.dn-contact-form-wrapper {
    width: 100%;
    max-width: 900px;
    margin: 0 auto;
    font-family: inherit;
    box-sizing: border-box;
}

/* 2. Grid System */
.dn-contact-row {
    display: flex;
    gap: 20px;
    margin-bottom: 20px;
    flex-wrap: wrap;
    align-items: flex-end;
}

.dn-contact-row p{
	margin-bottom: 0;
}

.dn-contact-col-half { 
    flex: 0 0 calc(50% - 10px);
    min-width: 280px; 
}

.dn-contact-col-full { 
    flex: 0 0 100%; 
}

/* 3. Inputs, Selects & Textarea */
.dn-contact-form-wrapper input[type="text"],
.dn-contact-form-wrapper input[type="email"],
.dn-contact-form-wrapper input[type="tel"],
.dn-contact-form-wrapper select,
.dn-contact-form-wrapper textarea {
    width: 100%;
    padding: 15px 25px;
    border-radius: 50px;
    border: 1px solid #f2f2f2;
    background-color: #ffffff;
    font-family: var(--Manrope), sans-serif;
    color: #666;
    font-size: 18px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
    box-sizing: border-box;
    transition: all 0.3s ease;
}

.dn-contact-form-wrapper input:focus,
.dn-contact-form-wrapper select:focus,
.dn-contact-form-wrapper textarea:focus {
    outline: none;
    border-color: #E76D6C;
    box-shadow: 0 2px 10px rgba(231, 109, 108, 0.1);
}

/* Textarea: No resize as requested */
.dn-contact-form-wrapper textarea {
    border-radius: 25px;
    min-height: 150px;
    resize: none !important;
}

/* Custom Select Arrow */
.dn-contact-form-wrapper select {
    appearance: none;
	text-overflow: ellipsis;
    -webkit-appearance: none;
    cursor: pointer;
    background-image: url('/wp-content/uploads/2025/11/caret-down.svg');
    background-repeat: no-repeat;
    background-position: right 20px center;
}

/* Labels */
.dn-contact-field-label {
    display: block;
    font-family: var(--Manrope), sans-serif;
    font-size: 16px;
    font-weight: 600;
    color: #4b4b4b;
    margin-bottom: 12px;
    margin-left: 8px;
}

/* 4. Radio Buttons (Identity & Preferred Contact) */
.dn-contact-radio-wrapper {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    margin-top: 5px;
	margin-left: 10px;
}

.dn-contact-radio-wrapper-alt p {
    display: flex;
    align-items: center;
    margin: 0;
    flex-wrap: wrap;
}

@media screen and (max-width: 500px) {
	.dn-contact-radio-wrapper-alt p {
			align-items: start;
			flex-direction: column;
	}
	
	.dn-contact-radio-wrapper-alt .wpcf7-list-item {
		margin-left: 8px !important;
	}
	
	.dn-contact-checkbox-wrapper {
		margin-left: -8px;
	}

}

.dn-contact-radio-label {
    font-family: var(--Manrope);
    font-weight: 600;
    font-size: 16px;
    color: #4b4b4b;
	margin-left: 8px;
    margin-right: 15px;
    white-space: nowrap;
}

.dn-contact-radio-wrapper-alt .wpcf7-form-control-wrap {
    display: inline-flex !important;
    align-items: center;
    width: auto !important;
}

/* Gap between radio options */
.dn-contact-radio-wrapper .wpcf7-list-item {
    margin: 0 30px 10px 0 !important; 
    display: inline-flex;
    align-items: center;
}

.dn-contact-radio-wrapper .wpcf7-list-item:last-child {
    margin-right: 0 !important;
}

.dn-contact-radio-wrapper .wpcf7-list-item label {
    display: flex;
    align-items: center;
    cursor: pointer;
	gap: 5px;
}

.dn-contact-radio-wrapper .wpcf7-list-item-label,
.dn-contact-radio-wrapper-alt .wpcf7-list-item-label{
    font-family: var(--Manrope), sans-serif;
    font-size: 16px;
    color: #4b4b4b;
}

/* Custom Radio Appearance */
.dn-contact-radio-wrapper input[type="radio"],
.dn-contact-radio-wrapper-alt input[type="radio"]{
    appearance: none;
    -webkit-appearance: none;
    width: 16px;
    height: 16px;
    border: 1px solid #E76D6C;
    border-radius: 50%;
    margin: 0;
    cursor: pointer;
    position: relative;
    background: #fff;
    outline: none;
    flex-shrink: 0;
}

.dn-contact-radio-wrapper input[type="radio"]:checked::after,
.dn-contact-radio-wrapper-alt input[type="radio"]:checked::after{
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 10px;
    height: 10px;
    background-color: #E76D6C;
    border-radius: 50%;
    transform: translate(-50%, -50%);
}

/* 5. Privacy Checkbox */
.dn-contact-checkbox-wrapper {
    font-family: var(--Manrope), sans-serif;
    font-size: 16px;
    color: #4b4b4b;
    margin-top: 10px;
}

.dn-contact-checkbox-wrapper input[type="checkbox"] {
    width: 20px;
    height: 20px;
    appearance: none;
    -webkit-appearance: none;
    background-color: #fff;
    border: 1px solid #E76D6C;
    margin-right: 12px;
    cursor: pointer;
    vertical-align: middle;
    position: relative;
}

.dn-contact-checkbox-wrapper input[type="checkbox"]:checked::after {
    content: '';
    display: block;
    width: 12px;
    height: 12px;
    background: #E76D6C;
    position: absolute;
    top: 3px;
    left: 3px;
}

.dn-contact-checkbox-wrapper a {
    text-decoration: underline;
	color: #4b4b4b;
}

/* 6. Submit Section */
.dn-contact-submit-wrapper {
    margin-top: 40px;
    padding-bottom: 20px;
}

.dn-contact-submit-btn-container {
    display: flex;
    justify-content: center;
}

.dn-contact-submit-btn {
    background-color: var(--red) !important;
    color: #ffffff !important;
    border: none;
    padding: 18px 70px;
    border-radius: 50px;
    font-family: var(--Manrope), sans-serif;
    font-weight: 700;
    font-size: 18px;
    cursor: pointer;
    transition: all 0.3s ease;
    letter-spacing: 0.5px;
}

.dn-contact-submit-btn:hover {
    box-shadow: 0 5px 15px rgba(0,0,0,0.1);
}

/* 7. Mobile Responsiveness */
@media screen and (max-width: 768px) {
    .dn-contact-row { 
        flex-direction: column; 
        align-items: stretch; 
        gap: 15px;
    }
    
    .dn-contact-col-half, 
    .dn-contact-col-full {
        width: 100%; 
    }
    
    .dn-contact-radio-wrapper { 
        flex-direction: row; 
        justify-content: flex-start;
    }

    .dn-contact-radio-wrapper .wpcf7-list-item {
        margin-right: 20px !important;
    }
}

@media screen and (max-width: 480px) {
    .dn-contact-radio-wrapper {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }
    .dn-contact-radio-label {
        margin-bottom: 5px;
    }
}

/*** Footer ***/
.gb-element-8e492033 {
	color: var(--white);
	position: relative;
}

/* Locations container */
.gb-element-c427d445 h2:first-of-type {
	font-family: var(--Gothic-ExtraBold);
	font-size: var(--generic-font);
}

.gb-element-b3c001ed h2 {
	font-family: var(--Gothic-SemiBold) !important;
}

/* Links list */
.wp-block-list.links-list li {
	font-size: var(--generic-font);
	font-style: var(--generic-style);
	line-height: var(--generic-height);
	font-family: var(--Gothic-ExtraBold);
}

.gb-element-eb9dedc9 .wp-block-list a {
	text-decoration: none !important;
}

.wp-block-list.links-list ul {
	list-style: none !important;
}

/* Media list and copyright */
.wp-block-list.media-list {
	display: flex;
	list-style-type: none;
	padding-left: 0;
}

.wp-block-list.media-list li {
	font-size: 14px !important;
	font-family: var(--Gothic-ExtraBold);
}

.wp-block-list.media-list li:not(:first-child)::before {
	content: "\25AA";
	font-size: 1em;
	margin-left: 10px;
	margin-right: 10px;
	position: relative;
}

.gb-element-2c10d5c7 > :last-child {
	font-family: var(--Gothic);
}

@media screen and (max-width: 400px) {
	.wp-block-list.media-list li:not(:first-child)::before {
		margin-left: 5px;
		margin-right: 5px;
	}

	.gb-element-8e492033 .wp-block-list li {
		font-size: 16px !important;
	}
}


/* Archive Page */
body.archive .site-main {
	margin-top: 160px;
	margin-bottom: 50px;
	max-width: 1300px;
	margin-left: auto;
	margin-right: auto;
}

body.archive .page-title {
	font-family: var(--Gothic-Bold);
}

body.archive .entry-title a {
	font-family: var(--Gothic-SemiBold);
	color: var(--red) !important;
}

body.archive .entry-summary,
body.archive .read-more{
	font-family: var(--Manrope);
}

body.archive  .read-more {
	color: var(--red);
	text-decoration: none;
}

body.archive .entry-summary,
body.archive .post-image{
	margin-top: 20px;
}

body.archive .post-image img {
	width: 100%;
}

/* 404 Page */
body.error404 .site-main {
	margin-top: 160px;
	margin-bottom: 50px;
	max-width: 1300px;
	display: flex;
	justify-content: center;
	text-align: center;
	margin-left: auto;
	margin-right: auto;
}

body.error404 .entry-title {
	font-family: var(--Gothic-SemiBold);
	color: var(--red);
}

body.error404 .entry-content {
	font-family: var(--Manrope);
}

body.error404 .search-field {
	border-top-left-radius: 10px;
	border-bottom-left-radius: 10px;
	font-family: var(--Manrope);
	margin-right: -4px;
}

body.error404 .search-submit {
	border-top-right-radius: 10px;
	border-bottom-right-radius: 10px;
	background-color: var(--red);
	color: var(--white);
	
}


@media screen and (max-width: 768px) {
	body.error404 .site-main {
		padding-left: 24px;
		padding-right: 24px;
	}	
	
	body.error404 .entry-title {
		font-size: 24px;
	}
}

/* Search page */
body.search .site-main {
	margin-top: 160px;
	margin-bottom: 50px;
	max-width: 1300px;
	margin-left: auto;
	margin-right: auto;
}

body.search .entry-title a {
	font-family: var(--Gothic-SemiBold);
	color: var(--red);
}

body.search .entry-summary,
body.search .post-image{
	margin-top: 20px;
}

body.search .entry-summary,
body.search .read-more{
	font-family: var(--Manrope);
}

body.search  .read-more {
	color: var(--red);
	text-decoration: none;
}

body.search .page-header,
body.search .inside-article .entry-meta {
	display: none;
}



@media screen and (max-width: 1024px) {
	body.search .site-main {
		padding-left: 32px;
		padding-right: 32px;
	}	
	
	body.search .entry-title {
		font-size: 32px;
	}
}

@media screen and (max-width: 768px) {
	body.search .site-main {
		padding-left: 24px;
		padding-right: 24px;
	}	
	
	body.search .entry-title {
		font-size: 24px;
	}
	
	body.search .entry-summary,
	body.search .read-more {
		font-size: 18px;
	}
}


/* No results Page */
body.search-no-results .site-main {
	margin-top: 160px;
	margin-bottom: 50px;
	display: flex;
	justify-content: center;
	text-align: center;
	max-width: 1300px;
	margin-left: auto;
	margin-right: auto;
}

body.search-no-results .entry-title {
	font-family: var(--Gothic-SemiBold);
	color: var(--red);
}

body.search-no-results .entry-content {
	font-family: var(--Manrope);
}

body.search-no-results .search-field {
	border-top-left-radius: 10px;
	border-bottom-left-radius: 10px;
	font-family: var(--Manrope);
	margin-right: -4px;
}

body.search-no-results .search-submit {
	border-top-right-radius: 10px;
	border-bottom-right-radius: 10px;
	background-color: var(--red);
	color: var(--white);
	
}


@media screen and (max-width: 768px) {
	body.search-no-results .site-main {
		padding-left: 24px;
		padding-right: 24px;
	}	
	
	body.search-no-results .entry-title {
		font-size: 24px;
	}
}

/* Donations admin (dn-subscriptions) */
body.toplevel_page_dn-subscriptions .wp-filter {
	padding: 12px 20px;
	margin-bottom: 15px;
}
body.toplevel_page_dn-subscriptions .filter-links {
	margin-top: 5px;
}
body.toplevel_page_dn-subscriptions .filter-links a {
	margin-right: 15px;
	padding: 5px 0;
}
body.toplevel_page_dn-subscriptions .dn-filter-tab-with-info {
	position: relative;
	display: inline-block;
	margin-right: 15px;
}
body.toplevel_page_dn-subscriptions .dn-filter-tab-with-info .dn-status-info-icon {
	position: absolute;
	right: -20px;
	width: 18px;
	height: 18px;
	padding: 0;
	border: none;
	border-radius: 50%;
	background: #2271b1;
	color: #fff;
	font-size: 12px;
	font-weight: 600;
	line-height: 1;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
body.toplevel_page_dn-subscriptions .dn-status-info-icon:hover {
	background: #135e96;
}
body.toplevel_page_dn-subscriptions .dn-status-info-icon:focus {
	outline: 2px solid #2271b1;
	outline-offset: 2px;
}
body.toplevel_page_dn-subscriptions .dn-status-info-content {
	max-width: 520px;
}
body.toplevel_page_dn-subscriptions .dn-status-info-body h3 {
	margin: 1em 0 0.5em;
	font-size: 14px;
}
body.toplevel_page_dn-subscriptions .dn-status-info-body .dn-status-info-intro {
	margin-top: 0;
}
body.toplevel_page_dn-subscriptions .dn-status-info-list {
	margin: 0.5em 0 0;
	padding-left: 1.5em;
}
body.toplevel_page_dn-subscriptions .dn-status-info-list li {
	margin-bottom: 0.75em;
	line-height: 1.5em;
}
body.toplevel_page_dn-subscriptions .dn-status-info-flow {
	margin: 0.75em 0 0;
	padding-left: 1.5em;
}
body.toplevel_page_dn-subscriptions .dn-status-info-flow li {
	margin-bottom: 0.85em;
	line-height: 1.5;
}
body.toplevel_page_dn-subscriptions .dn-status-info-flow .subscription-status {
	background: none;
	padding: 0;
	border-radius: 0;
	font-weight: 600;
}
body.toplevel_page_dn-subscriptions .dn-status-info-flow .status-pending {
	color: #856404;
}
body.toplevel_page_dn-subscriptions .dn-status-info-flow .status-active {
	color: #155724;
}
body.toplevel_page_dn-subscriptions .dn-status-info-flow .status-cancelled,
body.toplevel_page_dn-subscriptions .dn-status-info-flow .status-failed {
	color: #721c24;
}
body.toplevel_page_dn-subscriptions .dn-flow-btn {
	color: #135E96;
	font-weight: 600;
}
body.toplevel_page_dn-subscriptions .subscription-status {
	display: inline-block;
	padding: 4px 12px;
	border-radius: 3px;
	font-size: 12px;
	font-weight: 500;
}
body.toplevel_page_dn-subscriptions .status-pending {
	background: #fff3cd;
	color: #856404;
}
body.toplevel_page_dn-subscriptions .status-active {
	background: #d4edda;
	color: #155724;
}
body.toplevel_page_dn-subscriptions .status-cancelled,
body.toplevel_page_dn-subscriptions .status-failed {
	background: #f8d7da;
	color: #721c24;
}
body.toplevel_page_dn-subscriptions .subscription-modal {
	position: fixed;
	z-index: 1000;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0,0,0,0.4);
}
body.toplevel_page_dn-subscriptions .subscription-modal-content {
	background-color: #fefefe;
	margin: 7% auto;
	padding: 20px;
	border: 1px solid #888;
	width: 80%;
	max-width: 600px;
	border-radius: 4px;
}
body.toplevel_page_dn-subscriptions .subscription-modal-close {
	color: #aaa;
	float: right;
	font-size: 28px;
	font-weight: bold;
	cursor: pointer;
}
body.toplevel_page_dn-subscriptions .subscription-modal-close:hover {
	color: black;
}
body.toplevel_page_dn-subscriptions .subscription-details-table {
	width: 100%;
	margin-top: 20px;
}
body.toplevel_page_dn-subscriptions .subscription-details-table td {
	padding: 10px;
	border-bottom: 1px solid #ddd;
}
body.toplevel_page_dn-subscriptions .subscription-details-table td:first-child {
	font-weight: bold;
	width: 40%;
}