/*
Theme Name:     ClassiPress Child Theme
Theme URI:      http://appthemes.com/
Description:    Child theme for the ClassiPress theme
Author:         AppThemes
Author URI:     http://appthemes.com/
Template:       classipress
Version:        0.1.0

*/

/*@import url('https://fonts.googleapis.com/css2?family=Public+Sans:ital,wght@0,100..900;1,100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap');*/
@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&family=Public+Sans:ital,wght@0,100..900;1,100..900&display=swap');

/**.align-bottom-button .gb-grid-column>.gb-container>.gb-inside-container {
    display: flex;
    flex-direction: column;
    height: 100%;
}
.align-bottom-button .gb-grid-column>.gb-container>.gb-inside-container>.gb-button-wrapper {
    margin-top: auto;
}*/

body {
	font-family: "Inter", "Lato", sans-serif !important;
}

body.logged-in {
	#menu-header {
		.public-menu-link {
			display: none !important;
		}
	}
}

h1, h2, h3, h4, h5, h6 {
	font-family: "Public Sans";
	font-weight: 800;
	color: #4CA24E;
	text-transform: uppercase;
	letter-spacing: 3px;
}

.home-cover-extended {
	height: auto;
	min-height: none;
	max-height: none;
	padding: 30px 0 50px;
	overflow: hidden;
	position: relative;
	box-sizing: content-box;

	.entry-header {
		.entry-title {
			font-size: 35px;
			font-weight: 800;
			letter-spacing: 3.15px;
			line-height: 1em;
			text-transform: uppercase;
			margin-bottom: 48px !important;
		}
	}

	h2 {
		font-size: 35px;
		color: #fff;
		font-weight: 800;
		letter-spacing: 3.15px;
		margin-top: 85px;
	}

	a.more-link {
		margin-top: 8px;
		transition: transform 100ms linear;

		img {
			height: 55px;
			width: 55px;
		}
	}

	a.more-link:hover {

		img {
			transform: scale(1.05);
		}
	}
}

@media (min-width: 1024px) {
	.home-cover-extended {
		height: 80vh;
		max-height: 700px;
		min-height: 700px;
	}
}

.home-search-form-container {
	min-width: 0;
}

@media (min-width: 640px) {
	.home-search-form-container {
		min-width: 400px;
	}
}

/*
.home-cover-extended::before {
	content: "";
	display: block !important;
	position: absolute;
	right: 0;
	left: 0;
	top: 0;
	bottom: 0;
	pointer-events: none;
	z-index: 9999;
	background: linear-gradient(
        to bottom,
        rgba(0, 0, 0, 0) 30%,
        rgba(243, 243, 244, 1) 70%,
        rgba(243, 243, 244, 1) 100%
    );
}
*/

.header_main_res #logo {
padding-top: 0px !important;
	text-align:center;
}
.header .custom-logo-link img {
    max-height: 100px;
}
.header #top-bar-primary {
	padding-top: 1rem;
	padding-bottom: 1rem;
	margin-bottom: -1px;
}
.home-cover .summary p.banner-sub-title {
	line-height: 33px;
}
ul.repaus-pricing-table-list {
	margin-top: 20px;
}
.repaus-pricing-table-list li {
	padding-bottom:15px;
	font-size: 16px;
}
#memberships .plan-radio {
	width: 10%;
}
#memberships .plan-details {
	width: 65%;
}
#memberships .plan-costs {
	width: 25%;
}
.ad-display-header { 
	display: none; 
}
.desktop-ad-display { 
	display: block;
}
#report_description {
	display: none;
}
#post-1110 .login-form.register-form h2 {
	display: none;
}
.otp-auth-section {
	padding: 15px;
	border: 1px solid #dddddd;
	margin-bottom: 15px;
	margin-top: 15px;
}
.mt-15 {
	margin-top: 15px;
}
.alert.alert-danger {
	color: red;
}
.alert.alert-success {
	color: green;
	padding-bottom: 10px;
}
.bold {
	font-weight: 700;
}
.small-font {
	font-size: 14px;
}
.otp-verification-section {
	display: none;
}
.rel {
	position: relative;
}
.h-full {
	height: 100%;
}
.flex {
	display: flex;
	.grow {
		flex-grow: 1;
	}
	.shrink {
		flex-shrink: 1;
	}
}
.flex.flex-col {
	flex-direction: column;
}
.flex.align-center {
	align-items: center;
}
.flex.align-end {
	align-items: end;
}
.flex.justify-between {
	justify-content: space-between;
}

@media only screen and (max-width: 600px) {
	.ad-display-header { display: block; margin: 0 auto; }
	.desktop-ad-display { 
		display: none;
	}
}
@media only screen and (max-width: 768px) {
	#memberships .plan-radio, #memberships .plan-details, #memberships .plan-costs  {
		width: 100%;
	}
}

/* www.reptileclassifieds.com.au adjustments */

#menu-top-bar {
	li:not(:last-child) > * {
		margin-right: 8px;
	}
}

.page-header {
	margin-bottom: 1em;

	.archive-header {
		font-size: 1.5rem;
		color: #4CA24E;
		font-weight: 800;
		text-align: left;
		margin-right: auto;
		margin-bottom: 0;
	}

	.page-count {
		font-size: 0.9rem;
	}
}

.view-more-listings {

		> .button {
		display: inline-flex !important;
		align-items: center;
		justify-content: center;
		padding: 10px 15px 10px 35px !important;
		line-height: normal !important;
		border-radius: 6px;
		font-weight: bold;
		-webkit-transition: all 0.2s linear;
		position: relative;
		border: none;

		background-image: -webkit-linear-gradient(283deg, rgba(255, 255, 255, 0.1) 50%, transparent 55%), -webkit-linear-gradient(top, rgba(255, 255, 255, 0.15), transparent);
		background-color: #4CA24E !important;
		box-shadow: 0 0 0 1px #8EB37D inset, 0 0 0 2px rgba(255, 255, 255, 0.15) inset, 0 4px 0 0 #8EB37D, 0 4px 0 1px rgba(0, 0, 0, 0.1), 0 4px 4px 1px rgba(0, 0, 0, 0.1);
		color: white !important;

	}

	> .button:before {
		content: "";
		position: absolute;
		width: 20px;
		height: 20px;
		background: var(--icon-url) center / cover no-repeat;
		left: 10px;
		top: 10px;
		--icon-url: url("images/ellipsis_with_circle_45.png");
	}

	> .button:not(.disabled):hover {
		transform: scale(1.05);
		-webkit-transition: all 0.1s linear;
	}

}


.green-button,
.white-button
{
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	padding: 10px 15px;
	line-height: normal !important;
	border-radius: 6px;
	font-weight: bold;
	-webkit-transition: all 0.2s linear;
	white-space: nowrap;

	.button-icon {
		margin-right: 5px;
		width: 20px;
		height: 20px;
		display: inline-block;
		background: var(--icon-url) center / cover no-repeat;
	}

	.button-icon.star {
		--icon-url: url("images/star_45.png");
	}
	.button-icon.bump {
		--icon-url: url("images/bump_45.png");
	}
	.button-icon.search {
		--icon-url: url("images/search_45.png");
	}
	.button-icon.plus {
		--icon-url: url("images/plus_45.png");
	}
	.button-icon.user-plus {
		--icon-url: url("images/user_plus45.png");
	}
	.button-icon.unlock {
		--icon-url: url("images/unlock_45.png");
	}
	.button-icon.arrow-right {
		--icon-url: url("images/arrow_right45.png");
	}
	.button-icon.arrow-left {
		--icon-url: url("images/arrow_right45.png");
		transform: rotate(180deg);
	}
	.button-icon.ellipsis-with-circle {
		--icon-url: url("images/ellipsis_with_circle_45.png");
	}
}

.green-button {
	background-image: -webkit-linear-gradient(283deg,rgba(255, 255, 255, 0.1) 50%, transparent 55%), -webkit-linear-gradient(top, rgba(255, 255, 255, 0.15), transparent);
	background-color: #4CA24E;
	box-shadow: 0 0 0 1px #3C5630 inset, 0 0 0 2px rgba(255, 255, 255, 0.15) inset, 0 4px 0 0 #3C5630, 0 4px 0 1px rgba(0, 0, 0, 0.1), 0 4px 4px 1px rgba(0, 0, 0, 0.1);
	color: white !important;
}

.white-button {
	background-image: -webkit-linear-gradient(283deg, rgba(255, 255, 255, 1) 50%, transparent 55%), -webkit-linear-gradient(top, rgba(215, 215, 215, 0.95), transparent);
	background-color: #fff;
	box-shadow: 0 0 0 1px #8EB37D inset, 0 0 0 2px rgba(255, 255, 255, 0.15) inset, 0 4px 0 0 #8EB37D, 0 4px 0 1px rgba(0, 0, 0, 0.1), 0 4px 4px 1px rgba(0, 0, 0, 0.1);
	color: #8EB37D !important;
}

.green-button:not(.disabled):hover,
.white-button:not(.disabled):hover {
	transform: scale(1.05);
	-webkit-transition: all 0.1s linear;
}

.green-button:has(+ .green-button, + .white-button) {
	margin-right: 5px;
}

.green-button.disabled,
.white-button.disabled {
	background: gray !important;
	box-shadow: 0 0 0 1px rgba(0,0,0,0.3) inset, 0 0 0 2px rgba(255, 255, 255, 0.15) inset, 0 4px 0 0 rgba(0,0,0,0.7), 0 4px 0 1px rgba(0, 0, 0, 0.1), 0 4px 4px 1px rgba(0, 0, 0, 0.1);
}

.green-button.small-button {
	font-size: 0.8em;
	padding: 6px 8px;

	.button-icon {
		width: 15px;
		height: 15px;
	}
}

.medium-button {
	font-size: 15px;
}

.large-button {
	font-size: 20px;
}

.xlarge-button {
	font-size: 25px;
}

.theme-green #top-bar-secondary {
	padding: 0 0.5rem !important;
}

.theme-green #top-bar-secondary #menu-header {
	display: flex;
	flex-direction: row;
	align-items: stretch;
	justify-content: center;
	column-gap: 10px;
}

.theme-green #top-bar-secondary #menu-header > .menu-item {
	padding: 0.5rem 0;
	transition: background 150ms;
	display: flex;
	align-items: center;
}

.theme-green #top-bar-secondary #menu-header > .menu-item > a {
	color: white;
	font-weight: 600;
	transition: color 150ms, border 150ms;
	line-height: 1rem;
}

.theme-green #top-bar-secondary #menu-header > .menu-item:hover {
	background: white;
}

.theme-green #top-bar-secondary #menu-header > .menu-item:hover > a {
	color: #8EB37D;
}

body.home {
	#primary {
		margin-top: 0 !important;
	}
}

.ad-block {
	display: flex;
	align-items: stretch;
	justify-content: stretch;
	flex-wrap: nowrap;
	/*background: rgba(255, 135, 5, 1);*/
	background: transparent;
	/*padding-top: 50px;*/
	position: relative;

	.ad-container {
		border: none;
		flex: 1 1;
	}

	.ad-container.center {
		display: flex;
		align-items: center;
		justify-content: center;
	}
}

/* Only for dev environment */
ins.adsbygoogle {
	display: block;
	min-height: 100px;
	width: 100%;
	position: relative;
	text-align: center;
}

/* 
	< 640px Small
	< 1024px Medium
*/

/* Temporary Fixes */

.widget.widget_block:has(.ad-block) {
	background: none;
	border: none;
	box-shadow: none;
}

/***** All Listings Grid *****/

.list-view {
	--column-count: 1;
	--cell-gap: 2em;

	display: flex;
	align-items: stretch;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: var(--cell-gap);
	margin: 2em 0 0 0 !important;

	> div.column {
		width: calc( (100% - ((var(--column-count, 1) - 1) * var(--cell-gap, 2em))) / var(--column-count, 1));
		clear: none !important;
		float: none !important;
		padding: 0 !important;

		article.listing-item {
			height: 100% !important;
			margin-bottom: 0 !important;

			> .row {

				> div.columns {
					float: none !important;
					width: 100% !important;
					padding: 0 !important;

					.content-inner {
						padding-left: 2em !important;
					}
				}
			}
		}
	}

	> div.column:has(.ad-block) {
		width: 100%;
	}
}

.list-view:before {
	display: none !important;
}

@media (min-width: 640px) {
	.list-view {
		--column-count: 2;
	}
}

/***** Home Hero Featured Grid *****/
.home-featured-grid-shortcode {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 15px;
	height: 100%;
	padding: 15px;

	> div {
		text-align: center;

		ins.adsbygoogle {
			/*
			border-radius: 8px;
			background-color: rgba(0, 0, 0, 0.35);
			border: 2px solid #4CA24E;
			*/
			max-width: 700px;
			display: inline-block;
		}

		a.featured-listing-link {
			img {
				border-radius: 8px;
				background-color: rgba(0, 0, 0, 0.35);
				width: 100%;
				min-width: 100px;
				max-width: 225px;
				aspect-ratio: 1;
				object-fit: cover;
				object-position: center;
				border: 2px solid #4CA24E;
			}
		}
	}

	> div:has(ins.adsbygoogle) {
		grid-column: span 2;
		grid-row: 1;
	}
}

/* Small ~640px */
@media (min-width: 640px) {
}

/* Medium ~768px */
@media (min-width: 768px) {
	.home-featured-grid-shortcode {
		grid-template-columns: repeat(4, 1fr);

		> div:has(ins.adsbygoogle) {
			grid-column: span 4;

			ins.adsbygoogle {
				max-width: 400px;
			}
		}
	}
}

/* Large */
@media (min-width: 1024px) {
	.home-featured-grid-shortcode {
		> div:has(ins.adsbygoogle) {
			grid-row: 3;

			ins.adsbygoogle {
				max-width: 500px;
			}
		}
	}
}

/* Custom */
@media (min-width: 1236px) {
	.home-featured-grid-shortcode {
		grid-template-columns: repeat(6, 1fr);

		> div {
			a.featured-listing-link {
				img {
					max-width: 150px;
				}
			}
		}

		> div:has(ins.adsbygoogle) {
			grid-column: span 6;
			grid-row: 2;

			ins.adsbygoogle {
				max-width: 700px;
			}
		}
	}
}

/***** Home Latest Listings *****/

.latest-listings-extended,
.all-listings-extended {
	background: #fff;

	.home-widget-head-wrap {
		padding: 2rem 1rem 0 1rem;
		text-align: center;

		h2.home-widget-title {
			display: inline-block;
			margin-top: 80px;
			margin-bottom: 10px;
			position: relative;
			width: auto;
			font-size: 26px;
			font-weight: 800;
			line-height: 1em;
			letter-spacing: 3px;
			text-transform: uppercase;
		}

		h2.home-widget-title:before {
			content: "";
			position: absolute;
			top: -80px;
			left: 50%;
			width: 75px;
			height: 75px;
			transform: translateX(-50%);
			background-size: contain;
			background-position: center;
			background-repeat: no-repeat;
			background-image: url("images/new_sign_150.png");
		}

		p.home-widget-description {
			font-size: 18px;
			line-height: 1.2em;
		}
	}

	.listing-wrap {
		display: grid;
		grid-template-columns: repeat(1, minmax(0, 1fr));
		gap: 30px;
		margin: 0;
		padding: 0 1em;

		> .column {
			padding: 0;

			article.listing-item {
				height: 100%;
				margin-bottom: 0;
				border-radius: 4px;
				position: relative;

				.entry-thumbnail {
					position: relative;

					.item-cover {
						border-radius: 0;
					}
				}

				.entry-actions {
					position: absolute;
					right: 25px;
					bottom: 10px;
				}

				.content-inner {
					padding: 16px;
					display: flex;
					flex-direction: column;
					align-items: stretch;
					gap: 10px;

					a {
						display: flex;
						flex-direction: row;
						flex-wrap: nowrap;
						align-items: center;
						justify-content: stretch;
						height: 50px;

						h3.entry-title {
							color: #313131;
							font-size: 20px;
							font-weight: bold;
							line-height: 1.22em;
							width: 100%;
							height: 1.22em;
							white-space: normal;
							word-break: break-word;
							overflow: hidden;
							text-overflow: ellipsis;
							margin: 0;
							flex-grow: 1;
							flex-shrink: 1;
							text-transform: none;
							letter-spacing: initial;
						}
					}

					.entry-content {
						line-height: 1.2em;
						max-height: none;
					}

					.verified-user {
						margin-top: auto;
						color: #F9CA24;
						font-size: 13px;
						font-weight: bold;
						text-transform: uppercase;
						line-height: 2em;
						white-space: nowrap;
					}

					.entry-footer {
						margin-top: auto;
						position: relative !important;
						display: flex;
						column-gap: 2px;
						flex-wrap: nowrap;
						align-items: center;
						justify-content: stretch;
						
						.user-meta {
							display: flex;
							column-gap: 3px;
							flex-wrap: nowrap;
							justify-content: start;
							align-items: center;
							flex-direction: row;
							width: 50%;

							.user-avatar {
								position: relative;
								flex-shrink: 0;
								object-fit: cover;

								.avatar {
									border: 1px solid #EBEBEB;
								}

								.avatar-verified-badge {
									position: absolute;
									right: 2px;
									bottom: 0;
								}
							}

							.user-info {
								display: inline-flex;
								flex-direction: column;
								align-items: start;
								justify-content: stretch;
								flex-shrink: 1;
								min-width: 0px;

								.text-username {
									width: 100%;
									font-size: 15px;
									color: #8A8A8A;
									line-height: 1.2em;
									white-space: nowrap;
									overflow: hidden;
									text-overflow: ellipsis;
								}

								.text-verified-badge {
									font-size: 11px;
									color: #F9CA24;
									font-weight: 600;
									text-transform: uppercase;
									padding-left: 0;
									letter-spacing: 0.3px;
								}
							}
						}

						.post-meta {
							display: flex;
							flex-direction: column;
							align-items: end;
							justify-content: start;
							row-gap: 2px;
							flex-shrink: 1;
							width: 50%;

							.text-post-date,
							.text-post-stat {
								padding: 0;
								text-align: right;
							}
						}
					}
				}

				a.entry-thumbnail {
					position: relative;

					.ad-meta-img {
						position: absolute;
						left: 0;
						top: 0.5rem;
						height: 40px;
						width: auto;
						aspect-ratio: 2 / 1;
						transform: rotateZ(25deg);
						transition: opacity 300ms ease;
					}
				}
			}
		}
	}

	.view-more-listings {
		margin: 3rem 0;
	}

	.listing-wrap:before {
		display: none;
	}
}

.all-listings-extended {
	background: none;

	.listing-wrap {
		padding: 0;
		row-gap: 2.5em;
		column-gap: 30px;
		margin-bottom: 30px;

		.column.full-col {
			grid-column: 1 / -1;
		}
	}
}

@media (min-width: 769px) {

	.latest-listings-extended,
	.all-listings-extended {

		.home-widget-head-wrap {
			padding-top: 3rem;

			h2.home-widget-title {
				margin-top: 0;
				margin-left: 50px;
				text-transform: uppercase;
			}

			h2.home-widget-title:before {
				top: 50%;
				left: -60px;
				width: 50px;
				height: 50px;
				transform: translateY(-50%);
			}
		}
	}

	.latest-listings-extended {
		.listing-wrap {
			grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
		}
	}

}

@media (min-width: 1024px) {
	.latest-listings-extended,
	.all-listings-extended {
		.listing-wrap {
			grid-template-columns: repeat(var(--grid-column-count, 2), minmax(0, 1fr)) !important;
		}
	}
}

/***** Home Featured Slider *****/


.featured-listings-slider-extended {
	background: #fff;

	.home-widget-head-wrap {
		padding: 2rem 1rem 0 1rem;
		text-align: center;

		h2.home-widget-title {
			display: inline-block;
			margin-top: 80px;
			position: relative;
			width: auto;
			font-size: 26px;
			font-weight: 800;
			line-height: 1em;
			letter-spacing: 3px;
			text-transform: uppercase;
		}

		h2.home-widget-title:before {
			content: "";
			position: absolute;
			top: -80px;
			left: 50%;
			width: 75px;
			height: 75px;
			transform: translateX(-50%);
			background-size: contain;
			background-position: center;
			background-repeat: no-repeat;
			background-image: url("images/featured_sign_150.png");
		}

		p.home-widget-description {
			font-size: 18px;
			line-height: 1.2em;
		}
	}

	.items-featured-wrapper {
		width: 100%;
		text-align: center;

		.slick-slider {
			display: block;
			margin: auto 45px;

			.slick-list {
				
				padding: 0 10px;

				.slick-track {
					display: flex;
					flex-wrap: nowrap;
					align-items: stretch;
					justify-content: start;

					.slick-slide {
						height: auto !important;

						.content-wrap {
							height: 100%;

							.row {
								height: 100%;
								display: flex;
								flex-direction: column;
								justify-content: stretch;
								margin: 0;

								.columns {
									padding: 0;
								}

								.entry-thumbnail {
									> .entry-cover {
										border-radius: 4px 4px 0px 0px;
									}
								}

								.content-inner {
									background-color: #FFF7E7;
									flex-grow: 1;
									padding: 0;

									a.content-inner-link-wrapper {
										height: 100%;
										width: 100%;
										display: flex;
										flex-direction: column;
										align-items: start;
										gap: 10px;
										padding: 16px;
										text-align: left;
									}

									h3.entry-title {
										color: #313131;
										font-size: 20px;
										font-weight: bold;
										line-height: 1.22em;
										width: 100%;
										height: 1.22em;
										white-space: normal;
										word-break: break-word;
										overflow: hidden;
										text-overflow: ellipsis;
										margin: 0;
										text-transform: none;
										letter-spacing: initial;
									}

									.entry-meta {
										display: flex;
										align-items: center;
										justify-content: stretch;
										flex-wrap: nowrap;
										margin-top: auto;
										width: 100%;
										height: 30px;

										.ad-location {
											font-size: 12px;
											color: #8A8A8A;
										}

										.verified-user {
											margin-left: auto;
											color: #F9CA24;
											font-size: 13px;
											font-weight: bold;
											text-transform: capitalize;
											line-height: 2em;
											white-space: nowrap;
										}
									}

								}
							}
						}
					}
				}
			}
		}

		.slick-prev {
			left: 10px;
		}

		.slick-next {
			right: 10px;
		}

		.slick-prev,
		.slick-next {
			background: none;
			display: inline-flex;
			align-items: center;
			justify-content: center;
			padding: 10px 15px;
			line-height: normal;
			border-radius: 6px;
			font-weight: bold;
			-webkit-transition: all 0.2s linear;
			transform: translate(0, -50%) scale(1);
		}

		.slick-prev:before,
		.slick-next:before {
			position: absolute;
			content: "" !important;
			background: url("images/chevron_right_150.png");
			background-size: contain;
			background-position: center;
			background-repeat: no-repeat;
			width: 35px;
			height: 35px;
			opacity: 1;
		}

		.slick-prev:before {
			background-image: url("images/chevron_left_150.png");
		}

		.slick-prev:hover,
		.slick-next:hover,
		.slick-prev:focus,
		.slick-next:focus {
			background: none;
			transform: translate(0, -50%) scale(1.05);
			-webkit-transition: all 0.1s linear;
		}
	}

	.view-more-featured-listings {
		margin: 3rem 0;
	}
}

@media (min-width: 769px) {

	.featured-listings-slider-extended {

		.home-widget-head-wrap {
			padding-top: 3rem;

			h2.home-widget-title {
				margin-top: 0;
				margin-left: 60px;
			}

			h2.home-widget-title:before {
				top: 50%;
				left: -60px;
				width: 50px;
				height: 50px;
				transform: translateY(-50%);
			}

		}

	}

}

@media (hover:none) and (pointer: coarse) {
	.widget_cp_widget_listing_featured {
		padding: 2em 0 !important;

		.items-featured-wrapper {
			margin: 0;

			.slick-slider {
				margin: 0;
			}
			
			.slick-prev,
			.slick-next {
				display: none !important;
			}
		}
	}
}

/***** Pagination *****/

ul.pagination {
	display: flex;
	flex-direction: row;
	column-gap: 16px;
	justify-content: center;
	align-items: center;

	li {
		border: 2px solid transparent;
		border-radius: 100%;
		background-color: #4CA24E;
		height: 35px;
		width: 35px;
		aspect-ratio: 1;
		transition: all;
		transition-duration: 150ms;

		span.dots {
			color: rgba(86, 86, 86, 0.3) !important;
		}

		a {
			border: none !important;
			background: none !important;
			font-size: 16px;
			display: inline-flex;
			align-items: center;
			justify-content: center;
			height: 100%;
			width: 100%;
			color: white;
			text-align: center;
			padding: 0;

			span {
				background-color: transparent !important;
			}
		}

		a.first,
		a.prev,
		a.next,
		a.last {
			color: #4CA24E;
			width: 18px;
			height: 100%;
		}

		/*
		a.prev {
			color: transparent;
			background-image: url("images/arrow_left_150.png");
			background-size: contain;
			background-position: center;
			background-repeat: no-repeat;
			width: 35px;
			height: 35px;
		}

		a.next {
			color: transparent;
			background-image: url("images/arrow_right_150.png");
			background-size: contain;
			background-position: center;
			background-repeat: no-repeat;
			width: 35px;
			height: 35px;
		}

		a.prev,
		a.next {
			transition: all 0.1s linear;
		}

		a.prev:hover,
		a.next:hover {
			transform: scale(1.05);
			background-color: transparent !important;
		}
		*/
	}

	li:has(.dots,.first,.prev,.next,.last) {
		background-color: transparent;
	}

	li.current {
		a {
			font-weight: 800 !important;
		}
	}

	li.current,
	li:not(:has(.dots,.first,.prev,.next,.last)):hover {
		background: white !important;
		border: 2px solid #4CA24E !important;

		a {
			color: #4CA24E !important;

			span {
				background: transparent !important;
				color: #4CA24E !important;
			}
		}
	}
}

/***** Custom Ad *****/

.business-ad {
	background: #4CA24E;
	border: 2px solid #4CA24E;

	.text-container {
		display: flex;
		align-items: center;
		justify-content: center;
		flex-direction: column;
		height: 24px;

		span.title {
			text-transform: uppercase;
			text-align: center;
			font-size: 0.7em;
			line-height: 1.2em;
			letter-spacing: 1px;
			width: 100%;
			display: block;
			border-top: 2px solid #4CA24E;
			font-weight: 600;
			background-color: #4CA24E;
			color: #fff;
			transition-delay: 1s;
			transition: opacity 150ms linear, height 150ms linear;
			opacity: 1;
		}

		> a {
			opacity: 0;
			text-transform: uppercase;
			text-align: center;
			font-size: 0.5em;
			width: 100%;
			display: inline-block;
			border-top: 2px solid #4CA24E;
			font-weight: 600;
			background-color: #4CA24E;
			color: #fff;
			transition-delay: 1s;
			transition: opacity 150ms linear, height 150ms linear;
			max-height: 0px;
		}

		> a:hover {
			text-decoration: underline;
			color: #fff;
		}
	}
}

.business-ad:hover {
	.text-container {
		span.title {
			opacity: 0;
			max-height: 0px;
		}

		> a {
			opacity: 1;
			max-height: none;
		}
	}
}

/***** Responsive Classes *****/

/***** Search Form *****/

.searchbar-shortcode {
	background: rgba(76, 162, 78, 0.95);
	backdrop-filter: blur(2px);
	border-radius: 4px;
}

#searchbar { 
	margin-top: 25px;

	.column {
		border-radius: 4px !important;
		background: rgba(76, 162, 78);

		.search-form {
			margin: 1rem 0;

			.search-category-wrap,
			.search-state-wrap {
				margin-top: 0.5em;
			}

			.search-button-wrap {
				height: 100%;
				margin: 0.5em 0;
			}
		}
	}
}

/* Medium ~768px */
@media screen and (min-width: 768px) {
	
}

/* Large */
@media screen and (min-width: 1024px) {
	#searchbar {
		.column {
			.search-form {
				.search-category-wrap,
				.search-state-wrap {
					margin-top: 0;
				}
			}
		}
	}
}

@media (max-width: 40em) {
	#searchbar .search-form, .searchbar-shortcode .search-form {
		margin-bottom: 1rem;
	}
}

/***** Search Form Extended *****/

form.search-form-extended {
	background-color: #4CA24E;
	border-radius: 15px;
	position: relative;
	padding: var(--prop-t-spacing, 0px) var(--prop-r-spacing, 0px) var(--prop-b-spacing, 0px) var(--prop-l-spacing, 0px);

	img.img-prop {
		position: absolute;
		width: var(--prop-width, 'auto');
		height: var(--prop-height, 'auto');
		right: var(--prop-right, 0);
		left: var(--prop-left, 'auto');
		bottom: var(--prop-bottom, 0);
		top: var(--prop-top, 'auto');
		aspect-ratio: var(--prop-ratio, 'auto');
		z-index: 99;
		pointer-events: none;
		object-fit: contain;
		max-width: none;
	}

	.search-button-wrap {
		display: flex;
		flex-direction: row;
		flex-wrap: wrap;
		align-items: center;
		justify-content: stretch;
		row-gap: 5px;

		> .large-button {
			width: 100%;
		}
	}
}

@media (min-width: 640px) {
	form.search-form-extended {

		.search-button-wrap {
			flex-wrap: nowrap;
			justify-content: space-between;

			> .large-button {
				width: auto;
			}
		}
	}
}

@media (min-width: 1024px) {
	form.search-form-extended {
		max-width: 640px;
	}
}

.ad-entry-header {
	.ad-entry-header-title-container {
		display: flex;
		align-items: center;
		justify-content: space-between;
		flex-wrap: wrap;
		gap: 10px;
		margin: 20px 0;

		h1.entry-title {
			margin-bottom: 0;
			line-height: 1em;
			text-transform: none;
			font-weight: 600;
			letter-spacing: 1px;
		}
	}
}

@media (min-width: 1024px) {
	.ad-entry-header {
		.ad-entry-header-title-container {
			flex-wrap: nowrap;
		}
	}
}

/***** Price Tag *****/

.ad-loop-price {
	display: inline-flex;
	flex-direction: row;
	align-items: center;
	justify-content: start;
	gap: 5px;

	img.price-tag-icon {
		width: 25px;
		height: auto;
		aspect-ratio: 1;
	}

	.ask-post-price {
		color: #8A8A8A80;
	}

	.post-price {
		font-size: 22px;
		font-weight: 600;
		color: #4CA24E;
	}
}

.widget.widget-listing:has(.ad-single-borderless) {
	padding: 0;
	background-color: transparent;
	border: none !important;
	box-shadow: none !important;
}

.ad-single-notice {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 10px;
	margin: 0 5px;
	background: firebrick;
	gap: 10px;
	flex-wrap: nowrap;
	border-radius: 5px;

	img {
		width: 30px;
		height: 30px;
	}

	span {
		color: white;
	}
}

.ad-single-price {
	display: inline-flex;
	flex-direction: row;
	align-items: center;
	justify-content: start;
	gap: 5px;
	background-color: #4CA24E;
	padding: 2px 10px;
	border-radius: 5px;

	img.price-tag-icon {
		width: 35px;
		height: auto;
		aspect-ratio: 1;
	}

	.ask-post-price {
		font-size: 22px;
		font-weight: 600;
		color: white;
	}

	.post-price {
		font-size: 28px;
		font-weight: 600;
		color: white;
	}
}

.border-box-sizing {
	box-sizing: border-box;
}

.row-flex {
	padding: 24px;
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	align-items: start;
	justify-content: start;
	gap: var(--rf-gap, 10px);

	.order-1 {
		order: 1;
	}

	.order-2 {
		order: 2;
	}

	.order-3 {
		order: 3
	}
}

.row-flex.align-center {
	align-items: center;
}
.row-flex.justify-center {
	justify-content: center;
}
.row-flex.justify-space-between {
	justify-content: space-between;
}

.pt-0 {
	padding-top: 0;
}

.pt-6 {
	padding-top: 6em;
}

.mx-auto {
	margin-top: auto;
	margin-bottom: auto;
}

/* Small ~640px */
@media (min-width: 640px) {
	.row-flex {
		.sm-order-1 {
			order: 1;
		}

		.sm-order-2 {
			order: 2;
		}

		.sm-order-3 {
			order: 3
		}
	}

	.sm-pt-0 {
		padding-top: 0;
	}

	.sm-pt-6 {
		padding-top: 6em;
	}
}

/* Medium ~768px */
@media (min-width: 768px) {
	.row-flex {
		.md-order-1 {
			order: 1;
		}

		.md-order-2 {
			order: 2;
		}

		.md-order-3 {
			order: 3
		}
	}

	.md-pt-0 {
		padding-top: 0;
	}

	.md-pt-6 {
		padding-top: 6em;
	}
}

/* Large */
@media (min-width: 1024px) {
	.row-flex {
		.lg-order-1 {
			order: 1;
		}

		.lg-order-2 {
			order: 2;
		}

		.lg-order-3 {
			order: 3
		}
	}

	.lg-pt-0 {
		padding-top: 0;
	}

	.lg-pt-6 {
		padding-top: 6em;
	}
}

.nowrap {
	white-space: nowrap;
}

label.niche-label {
	font-size: var(--ncl-font-size, 12px);
	font-weight: var(--ncl-font-weight, 700);
	background-color: var(--ncl-bg-color, #fff);
	height: 45px;
	padding: 8px;
	border-radius: 4px;
	box-sizing: content-box;

	span.label {
		background: none;
		color: #535353;
		display: block;
		width: 100%;
		padding: 0;
		margin: 0;
	}

	input,
	input:focus {
		width: 100%;
		padding: 0;
		margin: 8px 0 0;
		height: 20px;
		box-sizing: border-box;
		border: none;
		box-shadow: none;
		background: transparent;
		font-size: var(--ncl-input-font-size, 17px);
		font-weight: var(--ncl-input-font-weight, 400);
		color: #000;
	}

	input::placeholder {
		font-size: inherit;
		font-weight: inherit;
		color: #ADADAD;
	}

	select {
		position: absolute;
		width: 100%;
		height: 100%;
		left: 0;
		top: 0;
		margin: 0;
    padding: 24px 8px 8px;
		box-sizing: border-box;
		border: none;
		box-shadow: none;
		background: transparent;
		font-size: var(--ncl-input-font-size, 17px);
		font-weight: var(--ncl-input-font-weight, 400);
		color: #000;
	}
}

label.niche-label:has(select) {
	position: relative;
}

label.niche-label:has(select)::after {
	content: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg' fill='currentColor'%3E%3Cpath d='m16.843 10.211c.108-.141.157-.3.157-.456 0-.389-.306-.755-.749-.755h-8.501c-.445 0-.75.367-.75.755 0 .157.05.316.159.457 1.203 1.554 3.252 4.199 4.258 5.498.142.184.36.29.592.29.23 0 .449-.107.591-.291 1.002-1.299 3.044-3.945 4.243-5.498z'/%3E%3C/svg%3E");
	position: absolute;
	right: 10px;
	top: calc(50% + 8px);
	transform: translateY(-50%);
	height: 25px;
	width: 25px;
	color: #000;
	pointer-events: none;
}

/* Needs improvement */
.footer-top .widget-title {
	white-space: nowrap;
}

/* Animations */

.slow-bounce {
	display: block;
	animation-name: slow-bounce;
	animation-duration: 1s;
	animation-iteration-count: infinite;
}

@keyframes slow-bounce {
	0%, 100% {
		transform: translateY(0);
	}

	60% {
		transform: translateY(50%);
	}
}