:is(input:not([type="checkbox"]):not([type="radio"]):not([type="submit"]):not([type="button"]), textarea):focus-visible {
	border-left: none;
	border-radius: 0;
	border-right: none;
	border-top: none;
	color: #666;
	padding: 3px;
	max-width: 80%;
}

:is(input:not([type="checkbox"]):not([type="radio"]):not([type="submit"]):not([type="button"]), textarea):hover {
	border-color: #999;
		max-width: 80%;
}

:is(input:not([type="checkbox"]):not([type="radio"]):not([type="submit"]):not([type="button"]), textarea, select) {
	border-left: none;
	border-radius: 0;
	border-right: none;
	border-top: none;
	color: var(--color-primary);
	outline: none;
	padding: 3px;
		max-width: 80%;
}

:is(input[type="date"], select) {
	box-sizing: border-box;
	flex: 1;
	max-width: 100%;
	min-width: 0;
	max-width: 80%;
}

:root {
	--brand-1: #f18232;
	--brand-2: #31b2de;
	--brand-3: #00a157;
	--brand-4: #5a57a5;
	--brand-5: #92c14c;
	--color-accent: var(--brand-1);
	--color-info: var(--brand-2);
	--color-primary: var(--brand-3);
	--container-max: 1200px;
	--font-body: "clother", sans-serif;
	--font-display: "clother", sans-serif;
	--gap-lg: 40px;
	--gap-md: 20px;
	--gap-sm: 10px;
	--header-height: 80px;
}

[class*=mec-sl-] {
	color: var(--color-primary);
	font-family: simple-line-icons;
	font-weight: 600;
	line-height: 1;
}

body.scrolling #sticky {
	position: relative;
}

input[type="submit"] {
	background: var(--color-accent);
	border-radius: 0;
	border: 1px solid var(--color-accent);
	color: #fff;
	cursor: pointer;
	font-family: var(--font-body);
	font-size: 1rem;
	line-height: 1;
	padding: 0.6em 1em 0.4em;
	max-width: 80%;
}

input[type="submit"]:hover {
	background: var(--brand-5);
	border: 1px solid var(--color-accent);
}

li span.post-date {
	display: none;
	margin-top: 5px;
}

main {
	border: 0px;
	display: block;
	margin-left: calc(50% - 50vw);
	padding-bottom: 1vh;
	padding-left: calc(50% - 50vw);
	padding-right: calc(50% - 50vw);
	padding-top: 1vh;
}

p, h1, h2, h3, h4, h5 {
	letter-spacing: 1px;
}

ul {
	display: block;
	list-style-type: disc;
	margin-block-end: 1em;
	margin-block-start: 1em;
	margin-inline-end: 1em;
	margin-inline-start: 1em;
	padding-inline-start: 0em;
	unicode-bidi: isolate;
}

ul {
	display: block;
	list-style-type: none;
	margin-block-end: 0em;
	margin-block-start: 0em;
	margin-inline-end: 0em;
	margin-inline-start: 0em;
	padding-inline-start: 0em;
	unicode-bidi: isolate;
}

#gridsearchbut, #reset-button {
	background: none;
	border-radius: 0;
	border: 2px solid var(--color-primary);
	color: var(--color-primary);
	cursor: pointer;
	display: inline-block;
	font-family: var(--font-body);
	font-size: 1rem;
	line-height: 1;
	margin: 20px !important;
	padding: 0.6em 1em 0.4em;
	position: relative;
	text-align: center;
}

#gridsearchbut::after, #reset-button::after {
	color: var(--color-primary);
	content: "";
	display: inline-block;
	transition: width 0.3s ease;
	visibility: hidden;
	width: 0;
}

#gridsearchbut:hover::after {
	color: var(--color-primary);
	content: " > ";
	display: inline-block;
	visibility: visible;
	width: 1em;
}

#label-filter, #location-filter, #tag-filter {
	border-left: none;
	border-radius: 0;
	border-right: none;
	border-top: none;
	color: #666;
	outline: none;
	padding: 3px;
}

#label-filter:focus-visible, #location-filter:focus-visible, #tag-filter:focus-visible {
	border-left: none;
	border-radius: 0;
	border-right: none;
	border-top: none;
	color: #666;
	outline: none;
	padding: 3px;
}

#main-content {
	margin-top: 100px;
}

#menu-footer-menu a {
	text-decoration: none;
}

#menu-footer-menu li {
	display: block;
	list-style-type: none;
	text-align: left;
}

#menu-footer-menu-1 {
	align-content: center;
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	gap: 10px;
	justify-content: center;
	margin-bottom: 10px;
}

#menu-footer-menu-1 a {
	text-decoration: none;
}

#menu-sub-menu a {
	font-size: 1em;
}

#pageclass {
	overflow: hidden;
	position: relative;
}

#pageclass {
	position: relative;
}

#pageclass ul, 
.service-hero ul, 
.location-hero ul {
	list-style: none;
	margin-left: 10px;
	padding-left: 0;
}

#pageclass ul li, 
.service-hero ul li, 
.location-hero ul li {
	display: block;
	font-family: var(--font-display);
	padding-bottom: 1em;
	padding-left: 1.8em;
	position: relative;
}

/* Base pentagon shape */
#pageclass ul li::before,
.service-hero ul li::before,
.location-hero ul li::before {
	content: "";
	position: absolute;
	left: -5px;
	top: 0.45em;
transform: translateY(-10%);
width: 14px;
height: 14px;

	mask: url('/wp-content/themes/rockhopper/assets/images/pentagon.svg') no-repeat center;
	-webkit-mask: url('/wp-content/themes/rockhopper/assets/images/pentagon.svg') no-repeat center;

	mask-size: contain;
	-webkit-mask-size: contain;

	background: var(--brand-1);
}
#pageclass ul li:nth-child(5n+1)::before,
.service-hero ul li:nth-child(5n+1)::before,
.location-hero ul li:nth-child(5n+1)::before {
	background: var(--brand-1);
}

#pageclass ul li:nth-child(5n+2)::before,
.service-hero ul li:nth-child(5n+2)::before,
.location-hero ul li:nth-child(5n+2)::before {
	background: var(--brand-2);
}

#pageclass ul li:nth-child(5n+3)::before,
.service-hero ul li:nth-child(5n+3)::before,
.location-hero ul li:nth-child(5n+3)::before {
	background: var(--brand-3);
}

#pageclass ul li:nth-child(5n+4)::before,
.service-hero ul li:nth-child(5n+4)::before,
.location-hero ul li:nth-child(5n+4)::before {
	background: var(--brand-4);
}

#pageclass ul li:nth-child(5n+5)::before,
.service-hero ul li:nth-child(5n+5)::before,
.location-hero ul li:nth-child(5n+5)::before {
	background: var(--brand-5);
}

#pageclass ul li:nth-child(odd)::before,
.service-hero ul li:nth-child(odd)::before,
.location-hero ul li:nth-child(odd)::before {
		transform: rotate(0deg);
}
#pageclass ul li:nth-child(even)::before,
.service-hero ul li:nth-child(even)::before,
.location-hero ul li:nth-child(even)::before {
		transform: rotate(108deg);
}

#pageclass::before, .service-hero::before, .location-hero::before {
	background-image: url('/wp-content/themes/rockhopper/assets/images/bridport-removals-icon.svg');
	background-position: var(--bg-random-x,50%) 100%;
	background-repeat: no-repeat;
	background-size: auto 100%;
	bottom: 0;
	content: '';
	left: 0;
	opacity: 0.05;
	position: absolute;
	right: 0;
	top: 0;
	transition: background-position 0.3s ease;
	z-index: -1;
}

#placetoggle {
	margin: 20px;
}

#placetoggle button {
	background-color: #000;
	border-radius: 0px;
	border: 2px solid #fff;
	color: #fff;
	font-weight: 500;
	margin-left: 5px;
	padding: 10px 15px;
}

#placetoggle button:hover {
	background-color: #fff;
	border-radius: 0px;
	border: 2px solid #000;
	color: #000;
	font-weight: 500;
	margin-left: 5px;
	padding: 10px 15px;
}

#post-content {
	display: flex;
	flex-direction: column;
	gap: 10px;
	justify-content: space-between;
	margin-left: calc(50% - 40vw);
	margin-right: calc(50% - 50vw);
	padding-bottom: 1vh;
	padding-left: calc(50% - 40vw);
	padding-right: calc(50% - 50vw);
	padding-top: 1vh;
}

#post-content #post-gallery .gallery-caption {
	color: #555;
	font-size: 0.85rem;
	margin-top: 5px;
}

#post-content #post-gallery .gallery-item {
	text-align: center;
}

#post-content #post-gallery .gallery-item img {
	border-radius: 5px;
	height: auto;
	max-width: 100%;
}

#post-content #post-tags .tag-list {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

#post-content #post-tags .tag-list a {
	color: #0073aa;
	font-size: 0.9rem;
	text-decoration: none;
}

#post-content #post-tags .tag-list a:hover {
	text-decoration: underline;
}

#post-content #post-tags .tag-list li {
	list-style: none;
}

#post-content .featured-image {
	background-position: center;
	background-size: cover;
	border-radius: 0;
	height: auto;
	position: relative;
	width: 100%;
}

#post-content .post-header {
	margin-bottom: 20px;
	text-align: left;
}

#post-content .post-meta {
	color: #222;
	font-size: 0.9rem;
	margin: 2px;
}

#post-content .post-title {
	color: #000;
	font-size: 2rem;
	font-weight: bold;
	margin: 2px;
	text-align: left;
}

#post-downloads, #post-gallery, #post-links {
	color: #000;
	margin-bottom: 30px;
}

#post-links h3, #post-downloads h3, #post-gallery h3 {
	color: #000;
	margin-bottom: 30px;
}

#reset-button:hover::after {
	color: var(--color-primary);
	content: " x ";
	display: inline-block;
	visibility: visible;
	width: 1em;
}

#sticky {
	height: 100vh;
	overflow: hidden;
	position: sticky;
	top: 0;
	z-index: 2;
}

#ui-datepicker-div {
	z-index: 9999 !important;
}

.base-experts {
	align-items: stretch;
	display: flex;
	flex-direction: column;
	margin-bottom: 10px;
	overflow: visible;
	padding-top: 20px;
}

.base2023 {
	align-items: flex-start;
	display: flex;
	flex-direction: column;
	margin-bottom: 10px;
}

.basicbutton {
	background: none;
	border-radius: 0;
	border: 0;
	display: inline-block;
	font-size: 1rem;
	line-height: 1;
	padding: 0.6em 1em 0.4em;
	position: relative;
}

.basicbutton:hover {
	letter-spacing: 2px;
}

.bodytext {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 20px 5px;
}

.brp-swiper__btn {
	background: #ffffff00;
	border-radius: 999px;
	border: 0px solid rgba(0,0,0,.15);
	cursor: pointer;
	height: 42px;
	pointer-events: all;
	position: relative;
	width: 42px;
}

.brp-swiper__btn--prev::before {
	transform: rotate(-135deg);
}

.brp-swiper__btn--next::before {
	transform: rotate(45deg);
}

.brp-swiper__btn::before {
	border-right: 4px solid rgba(0,0,0,.6);
	border-top: 4px solid rgba(0,0,0,.6);
	content: "";
	height: 10px;
	inset: 0;
	margin: auto;
	position: absolute;
	width: 10px;
}

.brp-swiper__nav {
	bottom: -10%;
	display: flex;
	justify-content: space-between;
	left: .5rem;
	pointer-events: none;
	position: absolute;
	right: .5rem;
	transform: translateY(-50%);
	z-index: 5;
}

.brp-swiper__pagination {
	margin-top: .75rem;
	text-align: center;
}

.btn {
	background: none;
	border-radius: 0;
	border: 0;
	cursor: pointer;
	display: inline-block;
	font-family: var(--font-body);
	font-size: 1rem;
	line-height: 1;
	padding: 0.6em 1em 0.4em;
	position: relative;
	text-align: center;
	text-decoration: none;
}

.btn--ghost {
	color: var(--color-primary);
	letter-spacing: 1px;
}

.btn--ghost:hover {
	letter-spacing: 2px;
}

.btn--outline-primary {
	border: 2px solid var(--color-primary);
	color: var(--color-primary);
}

.btn--outline-primary::after {
	color: var(--color-primary);
	content: "";
	display: inline-block;
	transition: width 0.3s ease;
	visibility: hidden;
	width: 0;
}

.btn--outline-primary:hover::after {
	content: " > ";
	visibility: visible;
	width: 1em;
}

.btn--solid-accent {
	background: var(--color-accent);
	color: #fff;
}

.btn--solid-accent:hover {
	background: var(--brand-5);
}

.call-container {
display: flex
;
    flex-direction: row;
    justify-content: flex-end;
    align-items: center;
    flex-wrap: nowrap;
    position: fixed;
    align-content: center;
    right: 10%;
}

.call-container button {
	background: var(--color-accent);
	border-radius: 0px;
	border: 0;
	color: #fff;
	cursor: pointer;
	line-height: 1.2rem;
	padding: 0.4em 1em 0.4em;
}

.column {
	width: 400px;
}

.contact-cta {
	padding: clamp(2rem,4vw,3.5rem) 0;
}

.contact-cta :is(h2, p) {
	color: inherit;
}

.contact-cta--bg-a {
	background: var(--brand-1);
	color: #fff;
}

.contact-cta--bg-b {
	background: var(--brand-2);
	color: #fff;
}

.contact-cta--bg-c {
	background: var(--brand-3);
	color: #fff;
}

.contact-cta--bg-d {
	background: var(--brand-4);
	color: #fff;
}

.contact-cta__card {
	border-radius: 1px;
	padding: 1.25rem;
}

.contact-cta__cardtitle {
	color: #fff;
	font-size: 1.05rem;
	margin: 0 0 1rem 0;
}

.contact-cta__container {
	margin: 0 auto;
	width: min(var(--container-max), calc(100% - 2rem));
}

.contact-cta__form :is(input, textarea, select) {
	width: 100%;
}

.contact-cta__grid {
	display: grid;
	gap: 1rem;
	grid-template-columns: 1fr 1.4fr;
}

.contact-cta__intro {
	margin: 0;
	max-width: 70ch;
	opacity: .95;
}

.contact-cta__label {
	font-size: .85rem;
	font-weight: 700;
	letter-spacing: .04em;
	opacity: .85;
}

.contact-cta__link {
	color: #fff;
	font-weight: 700;
	text-decoration: none;
}

.contact-cta__link:hover {
	color: #fff;
	text-decoration: underline;
}

.contact-cta__logo img {
	display: block;
	height: auto;
	margin-left: 2rem;
	width: clamp(84px,14vw,220px);
}

.contact-cta__row {
	border-top: 1px solid rgba(0,0,0,.08);
	display: grid;
	gap: .75rem;
	grid-template-columns: 90px 1fr;
	padding: .6rem 0;
		max-width: 80%;
}

.contact-cta__row:first-of-type {
	border-top: 0;
	padding-top: 0;
		max-width: 80%;
}

.contact-cta__social {
	border-top: 1px solid rgba(0,0,0,.08);
	margin-top: 1rem;
	padding-top: .9rem;
		max-width: 80%;
}

.contact-cta__socialicons {
	display: flex;
	flex-wrap: wrap;
	gap: .5rem;
	list-style: none;
	margin: .5rem 0 0 0;
	padding: 0;
}

.contact-cta__socialicons a {
	align-items: center;
	border-radius: 12px;
	color: #fff;
	display: inline-flex;
	height: 40px;
	justify-content: center;
	text-decoration: none;
	width: 40px;
}

.contact-cta__title {
	margin: 0 0 .35rem 0;
}

.contact-cta__top {
	align-items: center;
	display: grid;
	gap: 1.25rem;
	grid-template-columns: auto 1fr;
	margin-bottom: 1.25rem;
}

.contentdetailtag {
	color: var(--color-primary);
	font-family: var(--font-body);
	font-size: 1.3em;
	font-weight: 600;
	line-height: 1.2em;
	margin-bottom: 10px;
	margin-top: 30px;
	padding-bottom: 20px;
}

.custom-post {
	-webkit-filter: drop-shadow(0px 3px 8px rgba(0,0,0,0.15));
	background-color: #fff;
	border-radius: 1px;
	box-shadow: 0 0 5px rgba(0,0,0,0.1);
	display: flex;
	filter: drop-shadow(0px 3px 8px rgba(0,0,0,0.15));
	flex-basis: calc(25% - 20px);
	flex-direction: column;
	justify-content: space-between;
	margin: 10px;
	overflow: hidden;
	transition: transform 0.3s ease;
}

.custom-post-base {
	margin-bottom: 2px;
	position: relative;
	z-index: 2;
}

.custom-post-content {
	color: #333;
	font-size: 16px;
	font-weight: 500;
	line-height: 1.5;
	margin: 0;
	padding: 0px 20px 4px 20px;
}

.custom-post-date-big {
	color: #000;
	font-size: 1.3em;
	font-weight: 500;
	margin: 0;
	padding: 10px 20px;
	text-align: center;
}

.custom-post-grid {
	display: flex;
	flex-wrap: wrap;
	margin: 2px;
}

.custom-post-image {
	background-position: center;
	background-size: cover;
	padding-top: 100%;
	position: relative;
	width: 100%;
}

.custom-post-title {
	margin: 0 20px;
}

.custom-post-title a {
	text-align: left;
	text-decoration: none;
}

.custom-post-title a:visited {
	color: #000;
}

.custom-post-title h2 {
	margin: 10px 0 5px 0;
}

.custom-post:hover {
	transform: translateY(5px);
}

.cut-corners-all {
	--cut: 10px;
	clip-path: polygon(var(--cut) 0, calc(100% - var(--cut)) 0, 100% var(--cut), 100% calc(100% - var(--cut)), calc(100% - var(--cut)) 100%, var(--cut) 100%, 0 calc(100% - var(--cut)), 0 var(--cut));
	overflow: hidden;
}

.cut-corners {
  --cut: 10px;

  clip-path: polygon(
    0 0,
    100% 0,
    100% calc(100% - var(--cut)),
    calc(100% - var(--cut)) 100%,
    0 100%
  );

  overflow: hidden;
}

.cut-tr { clip-path: polygon(0 0, calc(100% - 18px) 0, 100% 18px, 100% 100%, 0 100%); }
.cut-tl { clip-path: polygon(18px 0, 100% 0, 100% 100%, 0 100%, 0 18px); }
.cut-br { clip-path: polygon(0 0, 100% 0, 100% calc(100% - 18px), calc(100% - 18px) 100%, 0 100%); }
.cut-bl { clip-path: polygon(0 0, 100% 0, 100% 100%, 18px 100%, 0 calc(100% - 18px)); }

.disable-background #pageclass::before {
	background-image: none;
}

.downloads-list a {
	font-size: 1.2em;
	margin: 20px;
	padding: 20px;
	text-decoration: none;
}

.downloads-list a::before {
	content: 'download: ';
}

.faq-a {
	padding: 1rem 2rem 2rem;
}

.faq-a > *:first-child {
	margin-top: 10px;
}

.faq-a > *:last-child {
	margin-bottom: 0;
}

.faq-block {
width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 20px 5px;
}

.faq-block > h2 {
	margin: 0 0 12px;
}

.faq-intro {
	margin: 0 0 18px;
}

.faq-item {
	background: #fff;
	border-radius: 12px;
	border: 0px solid rgba(0,0,0,0.08);
	box-shadow: 0 6px 18px rgba(0,0,0,0.06);
	overflow: hidden;
	position: relative;
}

.faq-item::before {
	content: "";
	height: 6px;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
}

.faq-item:nth-child(5n+1) {
	border-color: rgba(241,130,50,0.35);
}

.faq-item:nth-child(5n+1) > .faq-q {
	background: rgba(241,130,50,0.08);
}

.faq-item:nth-child(5n+1)::before {
	background: var(--brand-1);
}

.faq-item:nth-child(5n+2) {
	border-color: rgba(49,178,222,0.35);
}

.faq-item:nth-child(5n+2) > .faq-q {
	background: rgba(49,178,222,0.10);
}

.faq-item:nth-child(5n+2)::before {
	background: var(--brand-2);
}

.faq-item:nth-child(5n+3) {
	border-color: rgba(90,87,165,0.35);
}

.faq-item:nth-child(5n+3) > .faq-q {
	background: rgba(90,87,165,0.08);
}

.faq-item:nth-child(5n+3)::before {
	background: var(--brand-4);
}

.faq-item:nth-child(5n+4) {
	border-color: rgba(0,161,87,0.35);
}

.faq-item:nth-child(5n+4) > .faq-q {
	background: rgba(0,161,87,0.08);
}

.faq-item:nth-child(5n+4)::before {
	background: var(--brand-3);
}

.faq-item:nth-child(5n+5) {
	border-color: rgba(146,193,76,0.45);
}

.faq-item:nth-child(5n+5) > .faq-q {
	background: rgba(146,193,76,0.05);
}

.faq-item:nth-child(5n+5)::before {
	background: var(--brand-5);
}

.faq-item[open] > .faq-q::after {
	transform: rotate(-90deg);
}

.faq-items {
	display: grid;
	gap: 12px;
}

.faq-q {
	align-items: center;
	cursor: pointer;
	display: flex;
	font-weight: 700;
	gap: 14px;
	justify-content: space-between;
	list-style: none;
	padding: 2rem 3rem;
}

.faq-q::-webkit-details-marker {
	display: none;
}

.faq-q::after {
	content: ">";
	font-size: 1.4rem;
	line-height: 1;
	opacity: 0.9;
	transform: rotate(90deg);
	transition: transform 180ms ease;
}

.faq-q::marker {
	content: "";
}

.faq-q:focus, .faq-q:focus-visible {
	outline-offset: 0px;
	outline: 0px solid rgba(49,178,222,0.35);
}

.featured-image {
	height: auto;
	width: 100%;
}

.featured-image {
	display: block;
	height: auto;
	width: 400px;
}

.featured-image-box {
	box-sizing: border-box;
	display: block;
	margin: 0 auto;
	overflow: hidden;
	width: 100%;
}

.featurehead {
	align-content: center;
	align-items: center;
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: space-between;
	margin: 0px;
	padding: 0;
}

.footer-address {
	color: #fff;
	text-align: left;
}

.footer-address p {
	color: #fff;
}

.footer-blurb {
	align-content: flex-start;
	align-items: flex-start;
	display: flex;
	flex-direction: column;
	flex: 0.6;
	text-align: left;
}

.footer-branding {
	align-content: center;
	align-items: center;
	display: flex;
	flex-direction: column;
	flex-wrap: nowrap;
	flex: 1;
	justify-content: center;
	margin-bottom: 20px;
}

.footer-central {
	align-content: center;
	align-items: center;
	display: flex;
	flex-direction: column;
	flex-wrap: nowrap;
	flex: 1;
	justify-content: center;
	text-align: center;
}

.footer-col1 {
	display: none;
}

.footer-col2 {
	align-items: flex-end;
	flex: 1;
	text-align: center;
}

.footer-col3 {
	align-content: center;
	align-items: center;
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	flex: .5;
	font-size: .9em;
	justify-content: center;
	margin-top: 0px;
	text-align: center;
}

.footer-colmobile {
	display: flex;
}

.footer-contact {
	align-content: flex-start;
	align-items: flex-start;
	display: flex;
	flex-direction: column;
	text-align: left;
}

.footer-container {
	align-content: center;
	align-items: center;
	display: flex;
	flex-direction: column;
	flex-wrap: nowrap;
	gap: 10px;
	justify-content: space-around;
}

.footer-copyright p {
	color: #fff !important;
	font-size: 14px;
	margin-bottom: 30px;
}

.footer-phone a {
	font-size: 2rem;
	font-weight: 600;
	text-decoration: none;
}

.footer-sitedetails {
	align-content: flex-start;
	align-items: flex-start;
	display: flex;
	flex-direction: column;
	flex: 0.6;
}

.footer-social-links {
	display: flex;
	justify-content: center;
}

.footer-social-links ul {
	display: flex;
	flex-direction: row;
	justify-content: center;
}

.footercontent {
	align-items: flex-end;
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	justify-content: space-between;
	width: 100%;
}

.formsearchdate, .formsearchloc, .formsearchtext, .formsearchlabel, .gridsearchdiv {
	align-items: center;
	display: flex;
	flex-direction: row;
	gap: 10px;
	width: 100%;
}

.fullscreen-menu .menunav a:visited {
	color: #fff !important;
}

.fullscreen-menu.active {
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	padding-top: 3vh;
	transition: opacity 1.5s ease, transform 0.5s ease;
}

.gallery-grid {
	display: grid;
	gap: 5px;
	grid-template-columns: repeat(auto-fit,250px);
	justify-content: start;
	width: 100%;
}

.gallery-item {
	background-position: center;
	background-size: cover;
	border-radius: 0;
	height: 250px;
	width: 250px;
}

.gallery-item img {
	background-position: center;
	background-size: cover;
	position: relative;
	width: 100%;
}

.goodfor {
	color: #333;
	font-size: 0.9em;
	font-weight: 500;
	line-height: 1.5;
	margin: 0;
	padding: 0 20px;
}

.gridreadmorebutton {
	cursor: pointer;
	font-size: 0.8em;
	font-weight: 600;
	line-height: 0.9em;
	margin-top: auto;
	padding: 1px;
	text-align: center;
	text-transform: uppercase;
}

.gridreadmorebutton a {
	color: inherit;
	text-decoration: none;
}

.gridsearchdate {
	width: 100% !important;
}

.gridsearchdiv {
	display: flex;
	width: 50%;
}

.gridsearchdiv {
	align-items: center;
	flex-direction: row;
	margin-bottom: 20px;
	padding-top: 20px;
	width: 70%;
}

.gridsearchdiv > div {
	align-items: center;
	display: flex;
	gap: 10px;
	width: 100%;
}

.gridsearchdiv form {
	align-items: flex-start;
	display: flex;
	flex-direction: column;
	gap: 10px;
	justify-content: space-between;
	margin-bottom: 30px;
	width: 100%;
}

.gridsearchdiv form {
	align-items: flex-start;
	display: flex;
	flex-direction: column;
	gap: 10px;
	justify-content: space-between;
	margin-bottom: 30px;
	width: 100%;
}

.gridsearchdiv i {
	flex: 0 0 auto;
}

.gridsearchtext {
	flex: 2;
}

.gridsearchtext, #tag-filter, .formsearchdate {
	box-sizing: border-box;
	flex: 1;
	max-width: 100%;
	width: 100%;
}

.gridsection {
	margin-bottom: 20px;
	margin-top: 20px;
}

.gridsection {
	margin-bottom: 20px;
	margin-top: 20px;
	padding: 4rem 0;
}

.gridsection.bg-a {
	background: var(--brand-1);
}

.gridsection.bg-a .gridtitle, .gridsection.bg-b .gridtitle, .gridsection.bg-c .gridtitle, .gridsection.bg-d .gridtitle, .gridsection.bg-a .grid-description p, .gridsection.bg-b .grid-description p, .gridsection.bg-c .grid-description p, .gridsection.bg-d .grid-description p {
	color: #fff !important;
}

.gridsection.bg-b {
	background: var(--brand-2);
}

.gridsection.bg-c {
	background: var(--brand-3);
}

.gridsection.bg-d {
	background: var(--brand-4);
}

.gridtag2024 {
	--cut: 6px;
	background-color: var(--color-primary);
	color: #fff;
	display: inline-block;
	font-size: 0.9em;
	line-height: 2em;
	margin-left: 0.7em;
	margin-top: 0.7em;
	padding-left: 0.7em;
	padding-right: 0.7em;
	position: absolute;
	text-transform: uppercase;
	vertical-align: middle;
	z-index: 5;
}

.gridtitle {
	font-family: var(--font-display);
	font-size: 1.2em;
	font-weight: 500;
	letter-spacing: 1px;
	line-height: 2.2em;
	opacity: 0;
	padding-top: 20px;
	transform: translateX(-100px);
	transition: opacity 1.5s ease, transform 0.5s ease;
}

.gridtitle.visible {
	font-family: var(--font-display);
	font-size: 1.2em;
	font-weight: 500;
	line-height: 2.2em;
	opacity: 1;
	transform: translateX(0);
}

.gridtitle.visible::after {
	font-family: var(--font-display);
	font-size: 2.4em;
	font-weight: 500;
	opacity: 1;
	transform: translateX(0);
}

.hamburger {
	display: flex;
	margin: 10px 5px 10px 5px;
	right: 0;
	top: 0;
}

.header-center {
	flex: 1;
	text-align: right;
}

.header-container {
	align-content: space-around;
	align-items: center;
	display: flex;
	justify-content: space-between;
	width: 100%;
}

.header-left {
	display: flex;
	flex: 1;
	padding-top: 2px;
}

.header-right {
	flex: 0;
}

.hidden {
	display: none;
}

.kml-toggle-container button {
	background-color: #000;
	border-radius: 0px;
	border: 2px solid #fff;
	color: #fff;
	font-weight: 500;
	margin-left: 5px;
	padding: 10px 15px;
}

.kml-toggle-container button:hover {
	background-color: #fff;
	border-radius: 0px;
	border: 2px solid #000;
	color: #000;
	font-weight: 500;
	margin-left: 5px;
	padding: 10px 15px;
}

.links-list a {
	font-size: 1.2em;
	margin: 20px;
	padding: 20px;
	text-decoration: none;
}

.links-list a::before {
	content: 'visit: ';
}

.location-featured-services {
	border-top: 1px solid rgba(0,0,0,.1);
	padding: 2rem 0;
}

.location-featured-services--textonly {
	border-top: 1px solid rgba(0,0,0,.12);
	margin: auto;
	max-width: var(--container-max);
	padding-top: 1.5rem;
}

.location-featured-services__card {
	border-radius: 12px;
	border: 1px solid rgba(0,0,0,.1);
	padding: 1rem;
}

.location-featured-services__card a {
	display: block;
	text-decoration: none;
}

.location-featured-services__grid {
	display: grid;
	gap: 1rem;
	grid-template-columns: repeat(auto-fit, minmax(180px,1fr));
}

.location-featured-services__img {
	display: block;
	height: 100%;
	max-height: 320px;
	object-fit: cover;
	width: 100%;
}

.location-featured-services__img--placeholder {
	background: rgba(0,0,0,.06);
	border-radius: 14px;
	min-height: 220px;
}

.location-featured-services__inner {
	align-items: stretch;
	display: grid;
	gap: 1.25rem;
	grid-template-columns: 1fr;
}

.location-featured-services__intro {
	max-width: 70ch;
}

.location-featured-services__media {
	width: 100%;
}

.location-hero__container {
	align-items: start;
	display: grid;
	gap: 2.5rem;
	grid-template-areas: "image""head""map""desc";
	grid-template-columns: 1fr;
	margin: 0 auto;
	max-width: var(--container-max);
}

.location-hero__desc {
	grid-area: desc;
}

.location-hero__desc > *:first-child {
	margin-top: 0;
}

.location-hero__head {
	grid-area: head;
}

.location-hero__image {
	display: flex;
	grid-area: image;
	justify-content: center;
	padding: 0.5rem;
}

.location-hero__intro {
	font-size: 1.1rem;
	line-height: 1.6;
	max-width: 60ch;
	opacity: 0.9;
}

.location-hero__map {
	grid-area: map;
}

.location-hero__map .map-canvas, .location-hero__map #map, .location-hero__map .google-map {
	border-radius: 14px;
	min-height: 320px;
	overflow: hidden;
	width: 100%;
}

.location-hero__title {
	color: #000;
	font-size: clamp(1.8rem,3vw,2.6rem);
	margin: 0;
}

.mapcontrol {
	display: flex;
}

.mec-grid-event-location {
	color: #333;
	font-size: 0.8em;
	font-weight: 500;
	text-transform: uppercase;
}

.mec-wrap.colorskin-custom .mec-calendar .mec-calendar-events-side .mec-table-side-day {
	border: 0px;
}

.menu a {
	font-family: var(--font-body);
	font-size: 1.4rem;
	letter-spacing: 1px;
	line-height: 1.2;
	text-decoration: none;
}

.menu ul li, .menu li {
	display: block;
	list-style-type: none;
	margin-block-end: 1em;
	margin-block-start: 1em;
	margin-inline-end: 1em;
	margin-inline-start: 1em;
	padding-inline-start: 0em;
	text-align: left;
	unicode-bidi: isolate;
}

.menu-item.menu-item-has-children {
	position: relative;
}

.menu-item.menu-item-has-children.expanded > .sub-menu {
	display: block;
	max-height: 1000px;
	opacity: 1;
}

.menu-logo {
	display: flex;
	height: auto;
	margin-bottom: 10px;
	margin-top: 10px;
	max-width: 300px;
}

.menu-logo img {
	height: auto;
	max-width: 100%;
}

.menu-search-container {
	display: inline-block;
	z-index: 1000;
}

.menu-search-container .menu-search-input {
	border: none;
	flex-grow: 1;
	font-size: 14px;
	outline: none;
	padding: 5px;
}

.menu-search-container .menu-search-submit {
	background: none;
	border: none;
	cursor: pointer;
	padding: 5px;
}

.menu-search-container .menu-search-submit i {
	color: #000;
	font-size: 20px;
}

.menu-search-container.active .menu-search-form {
	transform: translateY(-50%) scaleX(1);
}

.menu-search-form {
	align-items: center;
	background: #fff;
	border-radius: 4px;
	box-shadow: 0 2px 5px rgba(0,0,0,0.2);
	display: flex;
	padding: 5px 10px;
	position: fixed;
	transform-origin: right center;
	transform: translateY(-50%) scaleX(0);
	transition: transform 0.3s ease-in-out;
}

.menu-search-icon {
	background: none;
	border: none;
	color: #fff;
	cursor: pointer;
	padding: 5px;
}

.menu-search-icon i {
	font-size: 20px;
}

.menu-search-icon:hover {
	color: #aaa;
}

.menubox {
	align-items: center;
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
}

.menunav {
	align-items: center;
	display: flex;
	flex-direction: column;
	position: relative;
}

.newstag {
	color: var(--color-primary);
	font-family: var(--font-body);
	font-size: .8rem;
	font-weight: 200;
	letter-spacing: 1px;
	padding-bottom: 0px;
	padding-top: 10px;
}

.nohighlight {
	cursor: pointer;
}

.nohighlight .sub-menu a:hover {
	color: var(--color-primary) !important;
}

.nohighlight a:hover {
	color: #fff !important;
}

.page {
	margin: 0 0 0 0em;
}

.pagecontent {
	border-left: 1px solid;
	flex: 1;
	margin-bottom: 50px;
	margin-top: 80px;
	padding-left: calc(50% - 40vw);
	padding-right: calc(50% - 30vw);
}

.pagecontent {
	border-left: 0px solid;
	flex: 1;
	margin-bottom: 50px;
	margin-top: 80px;
	padding-left: calc(50% - 40vw);
	padding-right: calc(50% - 30vw);
}

.pagegrid {
	margin-bottom: 35px;
	margin-top: 5px;
	padding-left: calc(50% - 40vw);
	padding-right: calc(50% - 40vw);
}

.pentagon-image {
	aspect-ratio: 1 / 1;
	max-width: 380px;
	position: relative;
	width: 100%;
}

.pentagon-image img {
	clip-path: polygon(50% 0%,100% 38%,82% 100%,18% 100%,0% 38%);
	display: block;
	filter: contrast(1.05) saturate(1.05);
	height: 100%;
	inset: 0;
	object-fit: cover;
	position: absolute;
	width: 100%;
}

.post-base-experts {
	margin-bottom: 2px;
	padding-left: 10px;
	padding-right: 10px;
	position: relative;
	z-index: 2;
}

.post-content-container {
	align-content: flex-start;
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	gap: 20px;
	justify-content: space-between;
	max-width: 120%;
}

.post-main-content {
	overflow: hidden;
}

.post-main-content {
	flex: 1;
}

.post-main-content h4 {
	color: var(--color-primary);
	font-family: var(--font-body);
	font-size: 1.3em;
	font-weight: 600;
	line-height: 1.2em;
	margin-bottom: 10px;
	margin-top: 30px;
	padding-bottom: 20px;
}

.postcontentcontainer {
	display: flex;
}

.postcontentimage {
	flex: 1;
}

.postcontentimage .featured-image-box {
	float: left;
	margin: 0 20px 20px 0;
	max-width: 100%;
	position: relative;
}

.postimageoverlay {
	background: rgba(0,0,0,0);
	border-radius: 0px;
	color: #fff;
	display: flex;
	flex-direction: row;
	gap: 5px;
	left: 10px;
	padding: 0px;
	position: absolute;
	top: 10px;
	z-index: 10;
}

.postsidebar {
	background: rgba(255,255,252,0.5);
	border-radius: 0px;
	box-shadow: 0 4px 6px rgba(255,80,1,0.1);
	padding: 20px;
}

.postsidebar-container {
	display: flex;
	flex: .6;
	padding-left: 20px;
	position: relative;
	width: 300px;
	z-index: 2;
}

.posttag {
	background-color: var(--color-primary);
	color: #fff;
	font-size: 0.9em;
	line-height: 2em;
	margin-left: 0.7em;
	margin-top: 0.7em;
	padding-left: 0.7em;
	padding-right: 0.7em;
	text-transform: uppercase;
	vertical-align: middle;
	z-index: 5;
}

.readmorediv {
	align-items: center;
	display: flex;
	font-size: 1.1rem;
	font-weight: 200;
	gap: 10px;
	justify-content: flex-end;
	letter-spacing: 1px;
	margin-right: 0px;
	opacity: 1;
	overflow: hidden;
	padding-bottom: 0px;
	padding-top: 5px;
	text-align: right;
}

.readmorediv a {
	padding-top: 4px;
}

.readmorespan {
	background: none;
	border-radius: 0;
	color: var(--color-primary);
	display: inline-block;
	font-family: var(--font-body);
	font-size: 1rem;
	font-weight: 400;
	line-height: 1;
	margin: 10px !important;
	padding: 0.6em 1em 0.4em;
	position: relative;
}

.readmorespan::after {
	color: var(--color-primary);
	content: "";
	display: inline-block;
	transition: width 0.3s ease;
	visibility: hidden;
	width: 0;
}

.readmorespan:hover::after {
	content: " > ";
	visibility: visible;
	width: 1em;
}

.reverseleft {
	display: flex;
	flex-direction: row-reverse;
}

.review-card__author {
	font-weight: 700;
	min-width: 0;
}

.review-card__meta {
	font-size: .9rem;
	margin-top: auto;
	opacity: .75;
	padding-top: .75rem;
}

.review-card__stars {
	flex: 0 0 auto;
	white-space: nowrap;
}

.review-card__text {
	flex: 1;
	line-height: 1.5;
}

.review-card__top {
	align-items: flex-start;
	display: flex;
	gap: 1rem;
	justify-content: space-between;
	margin-bottom: .5rem;
}

.reviews-slider {
	padding: 1.5rem 0;
}

.reviews-slider .brp-swiper {
	position: relative;
	width: 100%;
}

.reviews-slider .brp-swiper .swiper-slide {
	box-sizing: border-box;
	display: flex;
	flex: 0 0 100% !important;
	justify-content: center;
	width: 100% !important;
}

.reviews-slider .brp-swiper .swiper-wrapper {
	display: flex;
}

.reviews-slider .review-card {
	background: #fff;
	--cut: 20px;
	border: 0px solid rgba(0,0,0,.12);
	box-shadow: 0 6px 18px rgba(0,0,0,.06);
	display: flex;
	flex-direction: column;
	max-height: 240px;
	min-height: 220px;
	padding: 1.25rem;
	width: min(900px,100%);
}

.reviews-slider__frame {
	height: 300px;
}

.reviews-slider__header {
	align-items: flex-end;
	display: flex;
	gap: 1rem;
	justify-content: space-between;
	margin-bottom: .75rem;
}

.reviews-slider__meta {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	font-size: .95rem;
	gap: .75rem;
	justify-content: flex-end;
	opacity: .9;
}

.reviews-slider__title {
	margin: 0;
}

.rh-map {
	border-radius: 14px;
	height: 420px;
	overflow: hidden;
	width: 100%;
}

.rh-map--empty {
	align-items: center;
	background: #f3f3f3;
	display: flex;
	justify-content: center;
}

.scroll-text {
	font-size: 2.4em;
	opacity: 0;
	transform: translateX(-100px);
	transition: opacity 1.5s ease, transform 0.5s ease;
	width: 50%;
}

.scroll-text p {
	font-family: var(--font-display);
	font-size: 1.1em !important;
	font-style: normal;
	font-weight: 500;
	margin-bottom: 0px;
}

.scroll-text.visible {
	font-size: 2.4em;
	opacity: 1;
	transform: translateX(0);
}

.search-container {
	display: inline-block;
	right: 50px;
	top: 15px;
	z-index: 1000;
}

.search-container .search-input {
	background: #000;
	border: none;
	color: #fff;
	flex-grow: 1;
	font-size: 14px;
	outline: none;
	padding: 5px;
}

.search-container .search-submit {
	background: none;
	border: none;
	cursor: pointer;
	padding: 5px;
}

.search-container .search-submit i {
	background: #000;
	color: #fff;
	font-size: 20px;
}

.search-container :is(input:not([type="checkbox"]):not([type="radio"]):not([type="submit"]):not([type="button"]), textarea):focus-visible {
	border-bottom: 0;
	border-radius: 0;
	color: #fff;
	padding: 3px;
}

.search-container.active .search-form {
	transform: translateY(-50%) scaleX(1);
}

.search-container.active .search-icon i.fa-search:before {
	content: "\f00d";
}

.search-container.hidden {
	display: none;
}

.search-form {
	align-items: center;
	background: #000;
	border-radius: 0px;
	box-shadow: 0 2px 5px rgba(0,0,0,0.2);
	color: #fff;
	display: flex;
	padding: 5px 10px;
	position: absolute;
	right: 20%;
	top: 50%;
	transform-origin: right center;
	transform: translateY(-50%) scaleX(0);
	transition: transform 0.3s ease-in-out;
	width: 60%;
}

.search-icon {
	background: none;
	border: none;
	color: #fff;
	cursor: pointer;
	padding: 8px 5px 5px 5px;
}

.search-icon i {
	font-size: 20px;
}

.search-icon i.fa-search:before {
	content: "\f002";
}

.search-icon:hover {
	color: #aaa;
}

.searchbuttons {
	flex: 1;
}

.service-hero, .location-hero {
	margin-top: var(--header-height);
	padding: clamp(3rem,6vw,5rem) 1.2rem clamp(2rem,4vw,4rem);
}

.service-hero__container {
	align-items: center;
	display: grid;
	gap: 2.5rem;
	grid-template-areas: "text""media""desc";
	grid-template-columns: 1fr;
	margin: 0 auto;
	max-width: var(--container-max);
}

.service-hero__description > *:first-child {
	margin-top: 0;
}

.service-hero__intro {
	font-size: 1.1rem;
	line-height: 1.6;
	max-width: 60ch;
	opacity: 0.9;
}

.service-hero__media {
	display: flex;
	grid-area: media;
	justify-content: center;
	padding: 0.5rem;
}

.service-hero__text {
	grid-area: text;
}

.service-hero__title {
	color: #000;
	font-size: clamp(1.8rem,3vw,2.6rem);
	margin: 0;
}

.sidebar {
	background: 0;
	border-radius: 0px;
	border: 0px solid #ddd;
	box-shadow: 0;
	padding: 0px;
}


.sidebar-container {
	position: fixed;
	right: 30px;
	top: 60%;
	transform: translateY(-50%);
	width: 30px;
	z-index: 2;
}

.footer-social-links.sidebar {
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    align-items: flex-start;
    align-content: center;
}

.sidebar-container .footer-social-links ul {
    display: flex
;
    flex-direction: column;
    justify-content: center;
}
.sidebar-container .social-icons {
	gap: 0px;
}

.sidebar li {
    display: block;
    list-style-type: none;
    margin-block-end: 0em;
    margin-block-start: 0em;
   margin-inline-end: 0em;
    margin-inline-start: 0em; 
    padding-inline-start: 0em;
    unicode-bidi: isolate;
}

.site-header {
	border-bottom: 0px solid var(--brand-2);
	box-shadow: 0px 0px 5px var(--brand-2);
	left: 0;
	padding-bottom: 2px;
	padding-left: 60px;
	padding-right: 60px;
	padding-top: 2px;
	position: fixed;
	top: 0;
	width: 100%;
	z-index: 99;
}

.site-logo {
	display: flex;
	max-width: 200px;
	padding: 5px;
}

.site-logo img {
	transform-origin: left;
	transform: scale(1.2);
	transition: transform 0.6s ease-in-out;
}

.site-logo img.scrolled {
	transform: scale(0.8);
}

.social-icons .dashicons {
	-moz-osx-font-smoothing: grayscale;
	-webkit-font-smoothing: antialiased;
	display: inline-block;
	font-family: dashicons;
	font-size: 2em;
	font-style: normal;
	font-weight: 400;
	height: 2em;
	line-height: 1;
	text-align: center;
	text-decoration: inherit;
	text-rendering: auto;
	text-transform: none;
	transition: color .1s ease-in;
	vertical-align: top;
	width: 2em;
}

.sub-menu {
	display: none;
	max-height: 0;
	opacity: 0;
	overflow: hidden;
	padding-left: 0px;
	transition: max-height 0.3s ease, opacity 0.3s ease;
}

.sub-menu a {
	color: #333;
	display: block;
	font-size: 1rem;
	margin: 5px 0;
	text-decoration: none;
}

.title {
font-family: "clother", sans-serif;
	font-style: normal;
	font-weight: 400;
	letter-spacing: 1px;
}

.toggle-icon {
	background: none;
	border-color: #ccc #ccc #bbb;
	border-radius: 3px;
	border: 0px solid;
	color: #fff;
	line-height: 1;
	padding: 0.6em 1em 0.4em;
}

.ui-datepicker.ui-widget td a {
	margin: 2px;
	text-align: center;
}

.ui-datepicker.ui-widget td a:hover {
	background: var(--color-primary);
	color: #fff;
	margin: 2px;
	text-align: center;
}

.widget-title {
	color: #000;
	font-size: 1.4em;
	font-weight: 400;
	margin-bottom: 20px;
}

.widget_recent_entries {
	display: flex;
	flex-direction: column;
	flex-wrap: nowrap;
	gap: 3px;
}

.widget_recent_entries ul {
	display: flex;
	flex-direction: column;
	flex-wrap: nowrap;
	gap: 20px;
}

.wpcf7 textarea {
	height: 100px;
	max-width: 600px;
	width: 100%;
}

.wpcf7-form {
	max-width: 600px;
}

@media (max-width: 480px) {
	.column {
		max-width: 90%;
	}

	.gridsearchdiv form {
		align-items: flex-start;
		display: flex;
		flex-direction: column;
		gap: 10px;
		margin-bottom: 0px;
	}
}

@media (max-width: 768px) {
	.postsidebar-container {
		display: none;
	}
}

@media (max-width: 768px) {
	.postcontentimage .featured-image-box {
		display: block;
		float: none;
		margin: 0 auto 20px auto;
	}
}

@media (max-width: 768px) {
	.site-header {
		padding-left: 20px;
		padding-right: 10px;
	}
}

@media (max-width: 768px) {
	#menu-footer-menu-1 {
		align-content: center;
		flex-direction: row;
		flex-wrap: nowrap;
		justify-content: center;
		margin-bottom: 10px;
	}

	#menu-footer-menu-1 a {
		text-decoration: none;
	}

	#menu-footer-menu-1 li {
		display: block;
		list-style-type: none;
		text-align: center;
	}

	.footer-col3 {
		align-items: flex-end;
		display: flex;
		flex: 1;
		margin-top: 20px;
		text-align: left;
	}

	.footer-colmobile {
		align-content: center;
		align-items: center;
		display: flex;
		flex-direction: column;
		flex-wrap: nowrap;
		flex: 1;
	}

	.footer-container {
		justify-content: space-between;
	}
}

@media (max-width: 768px) {
	.sidebar-container {
		display: none;
	}
}

@media (max-width: 768px) {
	#pageclass::before {
		background-image: url('/wp-content/themes/rockhopper/assets/images/bridport-removals-icon.svg');
	}

	.blurb {
		font-size: .8em;
		text-align: center;
	}

	.column {
		max-width: 90%;
	}

	.footer-blurb {
		text-align: center;
		width: 100%;
	}

	.footer-contact {
		align-content: flex-start;
		align-items: center;
		display: flex;
		flex-direction: column;
		text-align: left;
	}

	.footer-item {
		text-align: center;
		width: 100%;
	}

	.footer-sitedetails {
		align-content: center;
		align-items: center;
		display: flex;
		flex-direction: column;
		flex: 0.8;
		justify-content: space-between;
	}

	.footercontent {
		align-items: center;
		flex-direction: column;
	}

	.gridsearchdiv {
		align-items: center;
		display: flex;
		flex-direction: column;
		gap: 10px;
		margin-bottom: 20px;
		padding-top: 20px;
		width: 100%;
	}

	.gridsearchdiv form {
		align-items: flex-start;
		display: flex;
		flex-direction: column;
		gap: 10px;
		margin-bottom: 0px;
		width: 100%;
	}

	.wpcf7 {
		max-width: 100%;
		padding: 15px;
	}

	.wpcf7 input, .wpcf7 textarea {
		width: 100%;
	}
}

@media (max-width: 780px) {
	.footer-social-links .social-icons .dashicons {
		-moz-osx-font-smoothing: grayscale;
		-webkit-font-smoothing: antialiased;
		display: inline-block;
		font-family: dashicons;
		font-size: 1.8em;
		font-style: normal;
		font-weight: 400;
		height: 1.2em;
		line-height: 1;
		text-align: center;
		text-decoration: inherit;
		text-rendering: auto;
		text-transform: none;
		transition: color .1s ease-in;
		vertical-align: top;
		width: 1.2em;
	}

	.footer-social-links ul {
		display: flex;
		flex-direction: column;
		justify-content: center;
	}

	.menu-footer .social-icons .dashicons {
		-moz-osx-font-smoothing: grayscale;
		-webkit-font-smoothing: antialiased;
		display: inline-block;
		font-family: dashicons;
		font-size: 1.2em;
		font-style: normal;
		font-weight: 400;
		height: 1.2em;
		line-height: 1;
		text-align: center;
		text-decoration: inherit;
		text-rendering: auto;
		text-transform: none;
		transition: color .1s ease-in;
		vertical-align: top;
		width: 1.2em;
	}
}

@media (max-width: 900px) {
	.contact-cta__grid {
		grid-template-columns: 1fr;
	}

	.contact-cta__logo img {
		margin: auto;
		width: clamp(84px,14vh,220px);
	}

	.contact-cta__top {
		grid-template-columns: 1fr;
	}

	.header-center .call-container {
		display: none;
	}
}

@media (min-width: 768px) {
	.gridsearchdiv {
		max-width: 50%;
	}
}

@media (min-width: 800px) {
	.location-featured-services__inner {
		align-items: center;
		grid-template-columns: minmax(240px,1fr) 2fr;
	}
}

@media (min-width: 900px) {
	.service-hero__container {
		align-items: start;
		grid-template-areas: "text media""desc media";
		grid-template-columns: 2fr 1fr;
	}

	.service-hero__container.left {
		grid-template-areas: "media text""media desc";
		grid-template-columns: 1fr 2fr;
	}

	.service-hero__container.left .service-hero__media {
		justify-content: flex-start;
	}

	.service-hero__container.right .service-hero__media {
		justify-content: flex-end;
	}

	.service-hero__description {
		grid-area: desc;
		max-width: 65ch;
	}

	.service-hero__media {
		grid-area: media;
		transform: translateY(-10px);
	}
}

@media (min-width: 900px) {
	.location-hero__container {
		grid-template-areas: "head image""map desc";
		grid-template-columns: 1fr 1fr;
	}

	.location-hero__head {
		max-width: 66%;
	}

	.location-hero__image {
		justify-content: flex-end;
	}

	.location-hero__image .pentagon-image {
		max-width: 380px;
	}
}

@media (min-width: 900px) {
	.rh-map {
		height: 500px;
	}
}

@media screen and (max-width: 480px) {
	.custom-post {
		flex-basis: calc(100% - 20px);
	}
}

@media screen and (max-width: 768px) {
	.bodytext {
		display: block;
		margin-left: calc(50% - 50vw);
		padding-bottom: 1vh;
		padding-left: 30px;
		padding-right: 30px;
		padding-top: 1vh;
	}

	.contentdetailtag {
		font-size: 1.2em;
		margin-top: 10px;
	}
}

@media screen and (max-width: 996px) {
	#post-content {
		display: flex;
		flex-direction: column !important;
		margin-left: calc(50% - 50vw);
		margin-right: calc(50% - 45vw);
		min-width: 95%;
		padding-left: calc(50% - 40vw);
		padding-right: calc(50% - 45vw);
	}
}

@media screen and (max-width: 996px) {
	.featured-image-box {
		width: 100%;
	}
}

@media screen and (max-width: 996px) {
	.pagecontent {
		border-left: 1px solid;
		margin-bottom: 50px;
		margin-top: 80px;
		padding-left: calc(50% - 45vw);
		padding-right: calc(50% - 45vw);
	}
}

@media screen and (max-width: 996px) {
	.post-content-container {
		flex-direction: column;
		max-width: 100%;
	}
}

@media screen and (min-width: 1280px) {
	.custom-post {
		flex-basis: calc(33.333% - 20px);
	}
}

@media screen and (min-width: 481px) and (max-width: 768px) {
	.custom-post {
		flex-basis: calc(50% - 20px);
	}
}

@media screen and (min-width: 769px) and (max-width: 1279px) {
	.custom-post {
		flex-basis: calc(33.333% - 20px);
	}
}



.moving-guides-footer{
padding:50px 0;
}

.guides-grid{
display:grid;
grid-template-columns: 1fr 1fr;
gap:40px;
align-items:start;
}

.guides-logo{
max-width:140px;
margin-bottom:15px;
}

.guides-intro{
max-width:420px;
}

.guides-right{
display:flex;
flex-direction:column;
gap:10px;
}

.guide-link{
font-weight:600;
text-decoration:none;
padding:6px 0;
border-bottom:1px solid rgba(0,0,0,0.08);
}

.guide-link:hover{
opacity:0.75;
}

@media (max-width: 800px){

.guides-grid{
grid-template-columns:1fr;
gap:25px;
}

}

/* Base bullet */
.guides-right .guide-link::before{
  content:"⬟";
  margin-right:8px;
  display:inline-block;      /* required for rotation */
  color: var(--brand-2);     /* fallback */
  transform-origin:center;
}

/* Cycle colours 1–5 */
.guides-right .guide-link:nth-child(5n+1)::before{ color: var(--brand-1); }
.guides-right .guide-link:nth-child(5n+2)::before{ color: var(--brand-2); }
.guides-right .guide-link:nth-child(5n+3)::before{ color: var(--brand-3); }
.guides-right .guide-link:nth-child(5n+4)::before{ color: var(--brand-4); }
.guides-right .guide-link:nth-child(5n+5)::before{ color: var(--brand-5); }

/* Alternate rotation */
.guides-right .guide-link:nth-child(odd)::before { transform: rotate(0deg); }
.guides-right .guide-link:nth-child(even)::before{ transform: rotate(108deg); }

.reviews-slider__frame {
	color: #000;
}
.reviews-slider__title {
		color: #fff;
}

.reviews-slider-wrap {
	padding: 30px 10px 0px 10px;
}

.brand-history{
  font-size:0.9rem;
  opacity:0.85;
  margin-top:0.6rem;
}

.brand-legacy{
  font-size:0.85rem;
  opacity:0.7;
}