/*
Theme Name: FI Group
Theme URI: https://thinkeq.co.uk
Author: ThinkEQ
Author URI: https://thinkeq.co.uk
Description: FI Group Wordpress Theme
Version: 1.0
Text Domain: figroup
*/
#html { margin-top: 0 !important; }
#html #wpadminbar { top: auto; width: auto; min-width: auto; bottom: 0; }
#html #wp-admin-bar-top-secondary, #html #wpadminbar .menupop, #wp-admin-bar-customize, #wp-admin-bar-updates, #wp-admin-bar-comments { display: none; }
@media (max-width:1199.98px) {
 #html #wpadminbar { display: none !important; }
 }
:root { --fig-white: #FFFFFF; --fig-black: #141616; --fig-grey: #C4BFB6; --fig-grey-light: #F7F7F7; --fig-green: #144733; --fig-blue: #20253C; --fig-font-primary: "Zalando Sans SemiExpanded", sans-serif; --fig-font-primary-alt: "Zalando Sans Expanded", sans-serif; --fig-font-secondary: "Playfair Display", serif; --fig-custom-ease: all 0.2s cubic-bezier(0.215, 0.61, 0.355, 1); --fig-shadow: 0 0 16px rgba(0, 0, 0, 0.16); }
/* =================reset css starts here=================  */
* { margin: 0; padding: 0; }
h1, h2, h3, h4, h5, h6, p, ul, li, body, html, form, fieldset, address, blockquote { margin: 0; padding: 0; outline: none; border: 0 }
a { text-decoration: none; border: 0; outline: 0; }
ul { list-style: none; }
a:focus, input:focus, textarea:focus, *:focus { outline: 0 !important; }
/* =================reset css ends here================= */
/* =================core css starts here================= */
body { font-family: var(--fig-font-primary); font-size: 15px; font-weight: 400; line-height: 1.6; letter-spacing: -0.003em; color: var(--fig-black); background: var(--fig-grey-light); -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
a, input, button { display: inline-block; text-decoration: none; color: inherit; outline: none; transition: all 0.2s ease-in; -webkit-transition: all 0.2s ease-in; }
a img { border: 0px none; }
a:hover { outline: none; color: var(--fig-green); text-decoration: none; }
a:active { outline: none; text-decoration: none; }
a:focus { outline: none; outline-offset: 0px; text-decoration: none; color: inherit; }
::-webkit-input-placeholder { color: #000; opacity: 0.5; }
::-moz-placeholder { color: #000; opacity: 0.5; }
:-moz-placeholder { color: #000; opacity: 0.5; }
:-ms-input-placeholder { color: #000; opacity: 0.5; }
img { max-width: 100%; border: 0; height: auto; }
h1, h2, h3, h4, h5, h6 { margin: 0px; padding: 0px; font-family: var(--fig-font-primary); font-weight: 500; line-height: 1.1; letter-spacing: -0.03em; color: inherit; margin-bottom: 24px; }
h1 { font-size: 70px; }
h2 { font-size: 50px; }
h3 { font-size: 40px; }
h4 { font-size: 30px; }
h5 { font-size: 25px; }
h6 { font-size: 20px; }
p { margin: 0px; padding: 0px; margin-bottom: 24px; }
strong { font-weight: 700; }
b { font-weight: 400; }
p:last-child { margin-bottom: 0; }
.btn { min-width: 136px; padding: 15px 19px; font-family: var(--fig-font-primary-alt); font-size: 14px; font-weight: 700; line-height: 1; letter-spacing: 0.005em; border-radius: 0; box-shadow: none; transition: var(--fig-custom-ease); }
.btn-icon { width: 16px; height: 16px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: var(--fig-custom-ease); }
.btn-icon.arrow { background: url('assets/images/btn-arrows-icon.svg') no-repeat center/contain; }
.btn-icon img { width: 100%; height: 100%; object-fit: contain; }
.btn:has(.btn-icon) { display: inline-flex; align-items: center; justify-content: space-between; gap: 24px; padding: 14px 19px; }
.btn-black, .btn-black:focus { color: var(--fig-grey); background-color: var(--fig-black); border-color: var(--fig-black); }
.btn-black:hover, .btn-black:active { color: var(--fig-black); background-color: var(--fig-grey); border-color: var(--fig-grey); }
.btn-black .btn-icon { filter: none; }
.btn-black:hover .btn-icon { filter: brightness(0); }
.btn-black-outline, .btn-black-outline:focus { color: var(--fig-black); background-color: transparent; border-color: var(--fig-black); }
.btn-black-outline:hover, .btn-black-outline:active { color: var(--fig-grey); background-color: var(--fig-black); border-color: var(--fig-black); }
.btn-black-outline .btn-icon { filter: brightness(0); }
.btn-black-outline:hover .btn-icon { filter: none; }
.btn-grey, .btn-grey:focus { color: var(--fig-black); background-color: var(--fig-grey); border-color: var(--fig-grey); }
.btn-grey:hover, .btn-grey:active { color: var(--fig-grey); background-color: var(--fig-black); border-color: var(--fig-black); }
.btn-grey .btn-icon { filter: brightness(0); }
.btn-grey:hover .btn-icon { filter: none; }
.btn-grey-outline, .btn-grey-outline:focus { color: var(--fig-grey); background-color: transparent; border-color: var(--fig-grey); }
.btn-grey-outline:hover, .btn-grey-outline:active { color: var(--fig-black); background-color: var(--fig-grey); border-color: var(--fig-grey); }
.btn-grey-outline .btn-icon { filter: none; }
.btn-grey-outline:hover .btn-icon { filter: brightness(0); }
.btn-green, .btn-green:focus { color: var(--fig-grey); background-color: var(--fig-green); border-color: var(--fig-green); }
.btn-green:hover, .btn-green:active { color: var(--fig-grey); background-color: var(--fig-black); border-color: var(--fig-black); }
.btn.btn-lg { width: 100%; padding: 21px 30px; }
.btn.btn-block { min-width: 100%; }
.add-index { position: relative; z-index: 9; }
.font-primary { font-family: var(--fig-font-primary); }
.font-primary-alt { font-family: var(--fig-font-primary-alt); }
.font-secondary { font-family: var(--fig-font-secondary); }
.bg-white { background-color: var(--fig-white) !important; color: var(--fig-black) !important; }
.bg-black { background-color: var(--fig-black) !important; color: var(--fig-grey-light) !important; }
.bg-grey { background-color: var(--fig-grey) !important; color: var(--fig-black) !important; }
.bg-grey-light { background-color: var(--fig-grey-light) !important; color: var(--fig-black) !important; }
.bg-green { background-color: var(--fig-green) !important; color: var(--fig-grey-light) !important; }
.bg-blue { background-color: var(--fig-blue) !important; color: var(--fig-grey-light) !important; }
.link { font-family: var(--fig-font-primary-alt); font-size: 14px; font-weight: 700; line-height: 1; letter-spacing: 0.005em; text-decoration: underline; text-underline-offset: 4px; background: transparent; border: 0; }
.link:hover { text-decoration: none; }
ul:not([class]) { list-style: square; margin-bottom: 24px; text-align: left; list-style-position: outside; margin-left: 14px; padding: 0; }
ul:not([class]) > li { position: relative; margin-bottom: 5px; }
ul:not([class]) > li:last-child { margin-bottom: 0; }
ul:not([class]) > li::marker { color: currentcolor; }
ol:not([class]) { list-style: numbers; margin-bottom: 24px; text-align: left; list-style-position: outside; margin-left: 14px; padding: 0; }
ol:not([class]) > li { position: relative; margin-bottom: 4px; }
ol:not([class]) > li:last-child { margin-bottom: 0; }
/* =================core css ends here================= */
/* ================= ContactForm7 Start ================= */
/* Form css start  */
.form-group { position: relative; }
.form-group + .form-group { margin-top: 32px; }
.form-label { font-size: 18px; line-height: 20px; font-weight: 600; letter-spacing: -0.025em; margin-bottom: 10px; }
.form-label { font-size: 18px; line-height: 20px; font-weight: 600; letter-spacing: -0.025em; margin-bottom: 10px; }
.form-control { height: 50px; padding: 12px 20px; font-size: 18px; line-height: 1.2; letter-spacing: -0.025em; color: var(--fig-black); border-radius: 0; border: 0; background: var(--fig-white); }
.form-control::placeholder { opacity: 1; }
.form-control:focus { box-shadow: none; color: var(--fig-black); }
.form-select { width: 100%; height: 50px; padding: 12px 20px; padding-right: 40px; font-size: 18px; line-height: 1.2; letter-spacing: -0.025em; color: var(--fig-black); background-color: var(--fig-white); border-radius: 0; border: 0; background-position: right 16px center; background-size: 15px 15px; }
.form-select:focus { box-shadow: none; color: var(--fig-black); }
textarea.form-control { height: 114px; resize: none; }
.bg-white .form-control { background: var(--fig-grey); }
.bg-white .form-select { background-color: var(--fig-grey); }
/* .form-control.datepicker { background: #fff url(assets/images/calendar-icon-black.svg) no-repeat center right/17px; background-position-x:calc(100% - 14px) ; }
*/
.form-btn-wrap { padding-left: 112px; margin-top: 0; position: relative; }
.form-check-group { padding-left: 112px; max-width: 580px; }
.form-check-label { color: var(--white); padding-left: 54px !important; }
.form-check-input { display: none; }
.form-check-label::before { position: absolute; content: ''; top: 0; left: 0; width: 20px; height: 20px; background: var(--fig-white); }
.form-check-label::after { content: ''; position: absolute; top: 8px; left: 7px; width: 10px; height: 6px; border-bottom: 1px solid #214670; border-left: 1px solid #214670; transform: rotate(-45deg) scale(0); transition: all 0.3s; }
.form-check-group .form-check-input:checked ~ .form-check-label::after { transform: rotate(-45deg) scale(1); }
input::-webkit-outer-spin-button, input::-webkit-inner-spin-button { -webkit-appearance: none }
input[type=number] { -moz-appearance: textfield }
.form-check { display: inline-block; vertical-align: top; width: 100%; color: var(--fig-black); padding: 0 }
.form-check input { display: none }
.form-check input + .wpcf7-list-item-label:before { content: ''; display: block; width: 20px; height: 20px; background: var(--fig-white); border: solid 1px var(--fig-white); position: absolute; left: 0; top: 4px; border-radius: 0; }
.form-check input + .wpcf7-list-item-label:after { content: ''; display: inline-block; width: 12px; height: 6px; position: absolute; left: 4px; top: 10px; -webkit-transition: all .12s ease-in; transition: all .12s ease-in; border: solid 3px var(--fig-blue); border-top: 0; border-right: 0; transform: rotate(-45deg); visibility: hidden; opacity: 0; }
.form-check input:checked + .wpcf7-list-item-label:after { visibility: visible; opacity: 1; }
.form-check label { padding-left: 30px; position: relative; display: inline-block; vertical-align: top; text-align: left; font-size: 18px; font-weight: 400; line-height: 1.35; letter-spacing: -0.025em; margin: 0; cursor: pointer }
.form-check label a { color: inherit; text-decoration: underline; display: inline; }
.form-check label a:hover { text-decoration: none }
.wpcf7-list-item { margin: 0 }
.wpcf7-list-item > label { display: inline-block; }
.wpcf7 .wpcf7-submit:disabled { background: 0 0 !important; border-color: inherit !important }
.form-text { color: #fff }
.wpcf7 .wpcf7-submit.btn-default:disabled, .wpcf7 .wpcf7-submit.btn-white-maroon:disabled, .wpcf7 .wpcf7-submit.btn-primary-white:disabled { border: solid 2px #999 !important; background: #999 !important; color: #fff !important }
div.wpcf7-validation-errors, div.wpcf7-acceptance-missing { border-color: #f00; position: relative; }
div.wpcf7 form.wpcf7-form span.ajax-loader { width: 24px; height: 24px; background-size: 20px; position: absolute; right: 0; margin: 0 15px; top: 50%; margin-top: -12px; z-index: 9; opacity: 1; }
span.wpcf7-not-valid-tip { top: 0; right: 0; padding: 0; bottom: auto; color: #fff; font-weight: 600; font-size: 14px; line-height: 1.3; letter-spacing: 0; position: absolute; top: 100%; margin-top: -11px; padding: 0; border-radius: 0px; background: #f00; padding: 0 5px; }
.wpcf7-form-control-wrap { position: static; width: 100%; }
.form-control.wpcf7-not-valid { border-color: #f00; }
div.wpcf7-response-output { margin: 30px 0 0 0 !important; background: transparent; border-width: 0px !important; border-radius: 0px; color: #fff !important; font-size: 18px !important; line-height: 22px; padding: 10px 15px !important; border-style: solid !important; border-color: #fff !important; font-weight: 700; text-align: center; }
.wpcf7 form.sent .wpcf7-response-output, .wpcf7 form.resetting .wpcf7-response-output { border-color: transparent !important; background: var(--fig-green); color: var(--fig-white) !important; }
.wpcf7 form.invalid .wpcf7-response-output { background: #f00; }
span.wpcf7-spinner { position: absolute; top: 8px; right: 8px; margin: 0; }
div.wpcf7 .wpcf7-submit:disabled { cursor: not-allowed; background: #999 !important; border-color: #999 !important; color: #666 !important; opacity: 0.7; }
.form-btn { position: relative; }
form br { display: none; }
.privacy-text { margin-top: 38px; font-size: 18px; line-height: 25px; letter-spacing: -0.025em; margin-bottom: 0; }
.submit-btn-wrap { margin-top: 16px; position: relative; }
/* .cf7-custom-success { background: rgba(0,0,0,0.6); padding: 15px; margin-top: 20px; color: var(--fig-white); font-weight: 700; }
.cf7-custom-success p:not(:last-child) { margin-bottom: 12px; }
*/
/* Form css end  */
/* ================= ContactForm7 End ================= */
/* ================= Hubspot form Css Start ================= */
.hs-form-field { position: relative; }
.hs-form-field:not(:last-child) { margin-bottom: 20px; }
.hs-form-field label { font-size: 15px; font-weight: 500; margin-bottom: 6px; }
.hs-input { display: block; width: 100%; height: 44px; padding: 14px 12px; font-size: 15px; line-height: 1.3; letter-spacing: -0.03em; color: var(--fig-black); background: var(--fig-white); border: 1px solid transparent; border-radius: 0; appearance: none; }
.hs-input:focus { border-color: #144633; }
textarea.hs-input { height: 94px; resize: none !important; }
.hs-input.invalid.error { border-color: #f00; }
.hs-error-msgs, .hs-error-msg { font-weight: 400 !important; color: #f00; }
.hs-button { min-width: 136px; padding: 16px 20px; padding-right: 60px; font-family: var(--fig-font-primary-alt); font-size: 14px; font-weight: 700; line-height: 1; letter-spacing: 0.005em; color: var(--fig-grey); background-color: var(--fig-green); background-image: url('assets/images/btn-arrows-icon.svg'); background-repeat: no-repeat; background-size: 16px 16px; background-position: calc(100% - 20px) center; border: 1px solid var(--fig-green); transition: var(--fig-custom-ease); }
.hs-button:hover { color: var(--fig-grey); background-color: var(--fig-black); border-color: var(--fig-black); }
/* ================= Hubspot form Css End ================= */ 
/* ============================== Header Start ====================================== */
body.open-menu { overflow: hidden; }
#header { color: var(--fig-grey-light); background: transparent; position: fixed; left: 0; top: 0; right: 0; padding: 0; z-index: 9999; transition: all 0.5s cubic-bezier(0.215, 0.61, 0.355, 1); -webkit-transition: all 0.5s cubic-bezier(0.215, 0.61, 0.355, 1); }
.fixed #header { background: var(--fig-black); box-shadow: 0 2px 4px rgba(0, 0, 0, .075) !important; }
.navbar { padding: 0; width: 100%; height: 160px; transition: .2s all ease-in; }
.fixed .navbar { height: 80px; }

:is(.page-template, .page-template-default.header-black, .page-content-hub) .navbar .navbar-nav  li.properties-search-icon::before {filter: brightness(0); }
:is(.page-template, .page-template-default.header-black, .page-content-hub) .navbar .navbar-nav  li.properties-search-icon.active::before {filter: brightness(1); }
:is(.page-template, .page-template-default.header-black, .page-content-hub).fixed .navbar .navbar-nav  li.properties-search-icon::before {filter: brightness(1); }
:is(.page-template, .page-template-default.header-black, .page-content-hub).fixed .navbar .navbar-nav  li.properties-search-icon.active::before {filter: brightness(1); }

.navbar-brand { width: 165px; padding: 0; margin: 0; position: relative; z-index: 999; }
body:is(.header-black, .error404, .page-template-standard-page, .page-template-properties-map-page, .page-template-properties-search-page, .search):not(.fixed, .open-menu, :has(.dropdown-menu.show)) .navbar-brand { filter: brightness(0); }
.navbar-expand-xl .navbar-nav > .nav-item { margin: 0 14px; }
.navbar-expand-xl .navbar-nav > .nav-item:first-child { margin-left: 0; }
.navbar-expand-xl .navbar-nav > .nav-item:last-child { margin-right: 0; }
.navbar-expand-xl .navbar-nav .nav-link { position: relative; padding: 0; font-family: var(--fig-font-primary-alt); font-size: 14px; font-weight: 700; line-height: 75px; letter-spacing: 0.02em; text-transform: capitalize; color: var(--fig-grey-light); }
.navbar-expand-xl .navbar-nav > .nav-item.active > .nav-link, .navbar-expand-xl .navbar-nav .nav-item:hover > .nav-link { color: var(--fig-grey); }
body:is(.header-black, .error404, .page-template-standard-page, .page-template-properties-map-page, .page-template-properties-search-page, .search):not(.fixed, .open-menu, :has(.dropdown-menu.show)) .navbar-expand-xl .navbar-nav > .nav-item > .nav-link { color: var(--fig-black); }
body:is(.header-black, .error404, .page-template-standard-page, .page-template-properties-map-page, .page-template-properties-search-page, .search):not(.fixed, .open-menu, :has(.dropdown-menu.show)) .navbar-expand-xl .navbar-nav > .nav-item.active > .nav-link, body:is(.header-black, .error404, .page-template-standard-page, .search):not(.fixed, .open-menu, :has(.dropdown-menu.show)) .navbar-expand-xl .navbar-nav .nav-item:hover > .nav-link { color: var(--fig-grey); }
.navbar-expand-xl .navbar-nav .dropdown:has(.show) .nav-link::after { transform: rotate(-180deg); }
.navbar-expand-xl .navbar-nav .dropdown > .nav-link::after { content: ""; display: inline-block; width: 9px; height: 13px; background: url(assets/images/dropdown-menu-icon.svg) no-repeat center/contain; margin-left: 4px; vertical-align: -2px; transition: all .2s ease; }
body:is(.header-black, .error404, .page-template-standard-page, .page-template-properties-search-page, .search):not(.fixed, .open-menu, :has(.dropdown-menu.show)) .navbar-expand-xl .navbar-nav .dropdown > .nav-link::after { filter: brightness(0); }
.dropdown-toggle::after { border: 0; }
.nav-inside { width: 100%; position: relative; padding: 0; }
.dropdown-close { display: none; }
.navbar-nav  li.properties-search-icon { display: inline-flex;}
.navbar-nav  li.properties-search-icon::before { content: ""; display: none; margin-right: 6px; width: 22px; height: 16px; align-self: center; background: url('assets/images/search-icon.svg') no-repeat center/contain; }
.navbar-nav  li.properties-search-icon::after { content: ""; display: inline-block; margin-left: 6px; width: 22px; height: 18px; align-self: center; background: url('assets/images/search-icon.svg') no-repeat center/contain; }
@media only screen and (min-width:1200px) {
 .navbar-expand-xl .navbar-nav .dropdown-menu { min-width: 154px; padding: 0; display: flex !important; flex-direction: column; top: 100% !important; left: 50%; transform: translateX(-50%); margin-top: 6px !important; color: var(--fig-grey-light); opacity: 0; visibility: hidden; background: transparent; box-shadow: none; border: 0; border-radius: 0; transition: all 0.1s ease-in; -webkit-transition: all 0.1s ease-in; }
.navbar-expand-xl .navbar-nav .dropdown:has(.show) > .dropdown-menu { opacity: 1; visibility: visible; margin-top: -6px !important; transition: var(--fig-custom-ease); -webkit-transition: var(--fig-custom-ease); }
.navbar-expand-xl .navbar-nav .dropdown-menu .dropdown-item { width: 100%; height: 100%; display: flex; align-items: center; position: relative; padding: 4px 0; font-size: 20px; font-weight: 500; line-height: 1.5; letter-spacing: -0.01em; white-space: normal; color: var(--fig-grey-light); background: transparent; transition: var(--fig-custom-ease); }
.navbar-expand-xl .navbar-nav .dropdown-menu li:focus > .dropdown-item, .navbar-expand-xl .navbar-nav .dropdown-menu li:hover > .dropdown-item, .navbar-expand-xl .navbar-nav .dropdown-menu li.active > .dropdown-item { color: var(--fig-grey) !important; background: transparent; transform: translateX(20px); }
.navbar-expand-xl .navbar-nav .dropdown-menu li.current-page-parent.active:not(:focus, :hover) > .dropdown-item { transform: translateX(20px); color: var(--fig-grey) !important; }
.navbar-expand-xl .navbar-nav .dropdown-menu li.current-page-parent.active:not(.current_page_ancestor, :focus, :hover) > .dropdown-item { transform: none; color: var(--fig-grey-light) !important; }
.overlay { width: 100%; height: 100%; position: fixed; top: 0; left: 0; background-color: var(--fig-black); opacity: 0; visibility: hidden; transition: var(--fig-custom-ease); z-index: 99; }
body:has(.dropdown .show) { overflow: hidden; }
body:has(.dropdown .show) .overlay { opacity: 0.95; visibility: visible; }
body:has(.dropdown .show) .header-right .btn, .fixed .header-right .btn { background-color: var(--fig-grey); color: var(--fig-black); border-color: var(--fig-grey); }
body:has(.dropdown .show) .header-right .btn:hover, .fixed .header-right .btn:hover { background-color: transparent; color: var(--fig-grey); border-color: var(--fig-grey); }
.dropdown-close { width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; margin-top: 16px; background: transparent; border: 0; }
.header-right { margin-left: 22px; }
.header-right .btn { min-width: 144px; }
.navbar-nav  li.properties-search-icon::before { display: inline-flex; }
.navbar-nav  li.properties-search-icon::after {display: none; }
 }
/* ============================== Header End ====================================== */
.content-container { padding: 120px 0; }
.container { width: 100%; max-width: 1320px; --bs-gutter-x: 1.875rem; position: relative; z-index: 9; }
.row { --bs-gutter-x: 1.875rem; }
.heading .subtitle { font-family: var(--fig-font-primary-alt); font-size: 14px; font-weight: 700; letter-spacing: 0.02em; margin-bottom: 6px; }
.heading .title { font-family: var(--fig-font-secondary); font-size: 40px; font-weight: 400; line-height: 1.3; margin-bottom: 0; }
.heading:has(.title + p) .title { margin-bottom: 30px; }
.overflow-x-clip { overflow-x: clip !important; }
.content-container p a:not(.btn), .content-container ul a:not(.btn) { color: currentColor; text-decoration: underline; text-underline-offset: 2px; }
.content-container p a:not(.btn):hover, .content-container ul a:not(.btn):hover { color: currentColor; text-decoration: none; }
:where(.homepage-hero-container, .development-hero-container, .about-us-hero-container, .level-2-hero-container) p a:not(.btn), :where(.homepage-hero-container, .development-hero-container, .about-us-hero-container, .level-2-hero-container) ul a:not(.btn) { color: currentColor; text-decoration: underline; text-underline-offset: 2px; }
:where(.homepage-hero-container, .development-hero-container, .about-us-hero-container, .level-2-hero-container) p a:not(.btn):hover, :where(.homepage-hero-container, .development-hero-container, .about-us-hero-container, .level-2-hero-container) ul a:not(.btn):hover { color: currentColor; text-decoration: none; }
/* GLOBAL SWIPER ARROW */
.custom-slider-navigation { margin-top: 55px; }
.custom-swiper-button { width: 58px; height: 58px; background: rgba(196, 190, 181, 0.5); transition: var(--fig-custom-ease); }
.custom-swiper-button:hover { opacity: 0.8; }
.custom-swiper-button img { width: 15px; height: 15px; object-fit: contain; }
.custom-swiper-button.swiper-button-disabled { opacity: 0.4; cursor: no-drop; filter: grayscale(100%); }
.bg-grey .custom-swiper-button { background: rgba(247, 247, 247, 0.4) }
/* Read More Css */
.read-more-content-wrapper { position: relative; margin-bottom: 40px; }
.read-more-content { font-size: 25px; font-weight: 500; line-height: 1.35; letter-spacing: -0.01em; }
.read-more-content-wrapper.collapsed { max-height: var(--max-height); overflow: hidden; mask-image: linear-gradient(to bottom, rgba(0, 0, 0) 0%, rgba(0, 0, 0, 0.95) 40%, rgba(0, 0, 0, 0)120%); }
.read-more-btn .read-more-text { display: inline; }
.read-more-btn .read-less-text { display: none; }
.read-more-btn.expanded .read-more-text { display: none; }
.read-more-btn.expanded .read-less-text { display: inline; }
.read-more-content ul:not([class]) { list-style: none; margin-bottom: 24px; text-align: left; margin-left: 0; padding: 0; }
.read-more-content ul:not([class]) > li { position: relative; margin-bottom: 5px; padding-left: 20px; }
.read-more-content ul:not([class]) > li:last-child { margin-bottom: 0; }
.read-more-content ul:not([class]) > li::before { content: ""; width: 5px; height: 5px; position: absolute; top: 15px; left: 0; background: currentcolor; }
/* Read More Css */
.top-shape { width: 100%; height: 74px; position: absolute; top: -1px; left: 0; clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 0%); }
.bottom-shape { width: 100%; height: 74px; position: absolute; bottom: -1px; left: 0; clip-path: polygon(0% 100%, 100% 100%, 100% 100%, 100% 0%); }
.half-top-shape { width: 100vw; height: 100%; position: absolute; bottom: calc(100% - 373px); left: 50%; transform: translateX(-50%); clip-path: polygon(0% 100%, 100% calc(100% - 196px), 100% 0%, 0% 0%); }
.half-bottom-shape { width: 100vw; height: 100%; position: absolute; top: 217px; left: 50%; transform: translateX(-50%); clip-path: polygon(0% 100%, 100% 100%, 100% 74px, 0% 0%); }
.has-top-shape { padding-top: 160px; }
.has-bottom-shape { padding-bottom: 160px; }
/* ============================== Blog Single Page Start ====================================== */
.blog-single-hero-content { padding: 190px 0 120px; color: var(--fig-grey-light); }
.blog-single-hero-bg { width: 100%; height: 100%; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: var(--fig-green); }
.blog-single-hero-bg img { width: 100%; height: 100%; object-fit: cover; }
.blog-single-hero-heading h1 { font-size: 70px; margin-bottom: 38px; }
.bs-hero-date { font-size: 30px; font-weight: 500; line-height: 1.1; letter-spacing: -0.03em; margin-bottom: 18px; }
.bsh-category-list { gap: 30px; }
.bsh-category-list li a { font-size: 20px; font-weight: 500; line-height: 1.5; letter-spacing: -0.01em; color: var(--fig-grey-light); text-underline-offset: 2px; }
.bsh-category-list li a:hover { text-decoration: underline; color: var(--fig-grey-light); }
.blog-single-hero-img { width: 100%; height: 100%; background: var(--fig-green); }
.blog-single-hero-img img { width: 100%; height: 100%; object-fit: cover; }
.blog-single-hero-quarter-circle { width: auto; height: 69.5%; position: absolute; bottom: 0; left: 0; }
.blog-single-hero-quarter-circle img { width: 100%; height: 100%; object-fit: contain; }
.blog-single-hero-lines { width: 100%; height: 100%; position: absolute; top: 4px; right: 0; transform: rotate(-44.95deg); transform-origin: top right; }
.blog-single-hero-line { width: 100%; height: 1px; position: absolute; top: 0; right: 0; background: var(--fig-grey); opacity: 0.5; }
.blog-single-hero-dashed-line { width: 100vw; height: 1px; position: absolute; top: 0; right: 320px; background-image: linear-gradient(90deg, var(--fig-grey), var(--fig-grey) 60%, transparent 60%, transparent 100%); background-size: 20px 1px; opacity: 0.5; transform: rotate(-89.75deg); transform-origin: top right; }
.blog-single-intro-content { font-size: 25px; font-weight: 500; line-height: 1.35; letter-spacing: -0.01em; }
.blog-single-content { margin-bottom: 75px; }
.blog-single-content h2, .blog-single-content h3 { font-family: var(--fig-font-secondary); font-size: 40px; font-weight: 400; line-height: 1.3; margin-bottom: 16px; }
.blog-single-content h4 { font-size: 35px; }
.blog-single-content h5 { font-size: 30px; }
.blog-single-content h6 { font-size: 25px; }
.blog-single-content p:has(img):not(:last-child) { margin-bottom: 50px; }
.blog-single-content p a:not(.btn), .blog-single-content ul a:not(.btn) { color: var(--fig-black); text-decoration: underline; text-underline-offset: 2px; }
.blog-single-content p a:not(.btn):hover, .blog-single-content ul a:not(.btn):hover { color: var(--fig-black); text-decoration: none; }
/* ============================== Blog Single Page End ====================================== */
.no-module-container, .error-container, .standard-container, .search-results-container { padding-top: 224px; }
.error-container h1 { font-size: 70px; }
.search-results-container h1 { font-size: 70px; }
.standard-container .standard-page-title { font-size: 70px; margin-bottom: 38px; }
.standard-container h2, .standard-container h3 { font-family: var(--fig-font-secondary); font-size: 40px; font-weight: 400; line-height: 1.3; margin-bottom: 16px; }
.standard-container h4 { font-size: 35px; }
.standard-container h5 { font-size: 30px; }
.standard-container h6 { font-size: 25px; }
.standard-container p:has(img):not(:last-child) { margin-bottom: 50px; }
.standard-container p a:not(.btn), .standard-container ul a:not(.btn) { color: var(--fig-black); text-decoration: underline; text-underline-offset: 2px; }
.standard-container p a:not(.btn):hover, .standard-container ul a:not(.btn):hover { color: var(--fig-black); text-decoration: none; }
/* ============================== Job Single Page Start ====================================== */
.load_more_jobs { min-width: 136px; padding: 14px 19px; display: inline-flex; align-items: center; justify-content: space-between; gap: 24px; font-family: var(--fig-font-primary-alt); font-size: 14px; font-weight: 700; line-height: 1; letter-spacing: 0.005em; color: var(--fig-grey); background-color: transparent; border: 1px solid var(--fig-grey); border-radius: 0; box-shadow: none; transition: var(--fig-custom-ease); margin-top: 40px; }
/* .load_more_jobs::after { content: ''; width: 16px; height: 16px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; background: url('assets/images/btn-arrows-icon.svg') no-repeat center/contain; filter: none; transition: var(--fig-custom-ease); } */
.load_more_jobs:hover, .load_more_jobs:active { color: var(--fig-black); background-color: var(--fig-grey); border-color: var(--fig-grey); }
.load_more_jobs:hover::after { filter: brightness(0); }
.job-single-hero-content { padding: 190px 0 120px; color: var(--fig-grey-light); }
.job-single-hero-bg { width: 100%; height: 100%; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: var(--fig-green); }
.job-single-hero-bg img { width: 100%; height: 100%; object-fit: cover; }
.job-single-hero-heading h1 { font-size: 70px; margin-bottom: 38px; }
.js-hero-location { font-size: 30px; font-weight: 500; line-height: 1.1; letter-spacing: -0.03em; margin-bottom: 18px; }
.js-hero-job-type { font-size: 20px; font-weight: 500; line-height: 1.5; letter-spacing: -0.01em; color: var(--fig-grey-light); }
.job-single-hero-img { width: 100%; height: 100%; background: var(--fig-green); }
.job-single-hero-img img { width: 100%; height: 100%; object-fit: cover; }
.job-single-hero-quarter-circle { width: auto; height: 69.5%; position: absolute; bottom: 0; left: 0; }
.job-single-hero-quarter-circle img { width: 100%; height: 100%; object-fit: contain; }
.job-single-hero-lines { width: 100%; height: 100%; position: absolute; top: 4px; right: 0; transform: rotate(-44.95deg); transform-origin: top right; }
.job-single-hero-line { width: 100%; height: 1px; position: absolute; top: 0; right: 0; background: var(--fig-grey); opacity: 0.5; }
.job-single-hero-dashed-line { width: 100vw; height: 1px; position: absolute; top: 0; right: 320px; background-image: linear-gradient(90deg, var(--fig-grey), var(--fig-grey) 60%, transparent 60%, transparent 100%); background-size: 20px 1px; opacity: 0.5; transform: rotate(-89.75deg); transform-origin: top right; }
.job-single-content h2, .job-single-content h3 { font-family: var(--fig-font-secondary); font-size: 40px; font-weight: 400; line-height: 1.3; margin-bottom: 16px; }
.job-single-content h4 { font-size: 35px; }
.job-single-content h5 { font-size: 30px; }
.job-single-content h6 { font-size: 25px; }
.job-single-content p:has(img):not(:last-child) { margin-bottom: 50px; }
.job-single-content p a:not(.btn), .job-single-content ul a:not(.btn) { color: var(--fig-black); text-decoration: underline; text-underline-offset: 2px; }
.job-single-content p a:not(.btn):hover, .job-single-content ul a:not(.btn):hover { color: var(--fig-black); text-decoration: none; }
.job-single-content .job_application.application { margin: 0; }
.job-single-content .application_button { min-width: 136px; margin: 0 !important; padding: 14px 19px !important; display: inline-flex !important; align-items: center; justify-content: space-between; gap: 24px; font-family: var(--fig-font-primary-alt); font-size: 14px !important; font-weight: 700; line-height: 1 !important; letter-spacing: 0.005em; color: var(--fig-grey); background-color: var(--fig-black); border: 1px solid var(--fig-black); border-radius: 0; box-shadow: none; transition: var(--fig-custom-ease); }
.job-single-content .application_button::after { content: ''; width: 16px; height: 16px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; background: url('assets/images/btn-arrows-icon.svg') no-repeat center/contain; filter: none; transition: var(--fig-custom-ease); }
.job-single-content .application_button:hover, .application_button:active { color: var(--fig-black); background-color: var(--fig-grey); border-color: var(--fig-grey); }
.job-single-content .application_button:hover::after { filter: brightness(0); }
.job-single-content .application_details { background: var(--fig-grey); border: 0 !important; box-shadow: none !important; padding: 0 !important; }
.job-single-content .application_details p { margin: 0 !important; padding: 12px 15px !important; }
.job-single-content .application_details p:not(:last-child) { margin-bottom: 16px !important; }
.job-single-content .single_job_listing .application .application_details:after { border-bottom-color: var(--fig-grey); }
.job-single-cta { border-top: 1px solid rgba(20, 22, 22, 0.1); margin-top: 50px; padding-top: 50px; }
.job-single-content .job-listing-meta.meta { display: none; }
/* ============================== Job Single Page End ====================================== */
/* ============================== Footer Start ====================================== */
.footer { color: var(--fig-grey-light); overflow: hidden; }
.footer a:not(.btn):hover { color: var(--fig-grey); }
.footer-bg { width: 100%; height: 100%; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: var(--fig-green); }
.footer-bg img { width: 100%; height: 100%; object-fit: cover; }
.footer-quarter-circle { width: auto; height: 100%; position: absolute; top: 0; right: 0; }
.footer-quarter-circle img { width: 100%; height: 100%; object-fit: contain; }
.footer-lines { height: 100%; position: absolute; top: 0; left: 0; right: 0; }
.footer-line.line-1 { width: 1px; height: 100%; position: absolute; top: 0; left: calc(50% - 96px); background: var(--fig-grey); opacity: 0.3; }
.footer-line.line-2 { width: 100vw; height: 1px; position: absolute; bottom: 0; left: 0; right: 0; background: var(--fig-grey); opacity: 0.3; }
.footer-dashed-line.line-1 { width: 100vw; height: 1px; position: absolute; bottom: 0; left: calc(50% - 96px); background-image: linear-gradient(90deg, var(--fig-grey), var(--fig-grey) 60%, transparent 60%, transparent 100%); background-size: 20px 1px; opacity: 0.3; transform: rotate(225.5deg); transform-origin: bottom left; }
.footer-dashed-line.line-2 { width: 100vw; height: 1px; position: absolute; top: 0; left: calc(50% - 96px); background-image: linear-gradient(90deg, var(--fig-grey), var(--fig-grey) 60%, transparent 60%, transparent 100%); background-size: 20px 1px; opacity: 0.3; transform: rotate(132.5deg); transform-origin: top left; }
.footer-cta { padding: 155px 0 144px; }
.footer-cta-left h3 { font-size: 50px; margin-bottom: 0; }
.footer-shape { width: 80px; height: 93px; position: absolute; top: 94px; right: 12px; }
.footer-main { padding: 118px 0 10px; }
.footer-logo { width: 177px; margin-bottom: 53px; }
.footer-logo img { width: 100%; height: 100%; object-fit: contain; }
.footer-nav-wrapper { gap: 30px; }
.footer-col { width: calc(25% - 22.5px); max-width: 190px; }
.footer-col h4 { font-size: 25px; font-weight: 500; line-height: 1.35; letter-spacing: -0.01em; margin-bottom: 12px; }
.footer-nav li + li { margin-top: 4px; }
.footer-nav li a { font-family: var(--fig-font-primary-alt); font-size: 14px; font-weight: 700; line-height: 1.1; letter-spacing: 0.005em; }
.social-links { font-size: 20px; gap: 10px; margin-top: 56px; }
.footer-contact span { display: inline-block; font-family: var(--fig-font-primary-alt); font-size: 14px; font-weight: 700; line-height: 1.1; letter-spacing: 0.005em; margin-bottom: 11px; }
.footer-contact-item { font-size: 12px; font-weight: 400; line-height: 1.6; letter-spacing: -0.003em; }
.footer-contact-item h5 { font-family: var(--fig-font-primary-alt); font-size: 14px; font-weight: 700; line-height: 1.1; letter-spacing: 0.005em; margin-bottom: 10px; }
.footer-contact-item p:not(:last-child) { margin-bottom: 0; }
.footer-contact-item + .footer-contact-item { margin-top: 9px; }
.copyright { font-size: 15px; font-weight: 400; line-height: 1.6; letter-spacing: -0.003em; margin-top: 128px; opacity: 0.5; }
/* ============================== Footer End ====================================== */
/* ==================== Properties Search Page Start ==================== */
.properties-hero-container { min-height: 556px; padding: 238px 0 0; }
.property-hero-content h1 { font-size: 70px; text-align: center; width: 100%; max-width: 900px; margin: 0 auto; }
.properties-hero-search-holder { margin-top: 30px; }
.properties-hero-search-wrapper { position: relative; width: 100%; bottom: -58px; margin-top: 80px; }
.properties-hero-search-box { padding: 24px 40px 24px 64px; background: rgba(196, 191, 182, 0.2); border-radius: 90px; }
/* Equal width for all five search columns (postcode, name, type, size, checkbox) */
.properties-hero-search-postcode, .properties-hero-search-name, .properties-hero-search-type, .properties-hero-search-size, .properties-hero-search-exclude { flex: 1 1 0%; min-width: 0; }
.properties-hero-search-name, .properties-hero-search-type, .properties-hero-search-size { border-left: 1px solid var(--fig-black); padding-left: 23px; padding-right: 12px; }
.properties-hero-search-exclude { padding-left: 23px; padding-right: 12px; }
.ph-search-btn-wrap { flex: 0 0 auto; }
.properties-hero-search-location-wrap { display: flex; align-items: center; gap: 8px; width: 100%; }
.properties-hero-search-location-icon { width: 18px; height: auto; flex-shrink: 0; }
.properties-hero-search-location-wrap .form-control { flex: 1; min-width: 0; }
.properties-hero-search-box .form-label { font-size: 12px; font-weight: 500; letter-spacing: -0.003em; margin-bottom: 6px; }
.properties-hero-search-box .form-control { width: 100%; height: auto; padding: 0; font-size: 16px; font-weight: 500; line-height: 1.6; letter-spacing: -0.03em; color: var(--fig-black); background-color: transparent; border: 0; border-radius: 0; }
.properties-hero-search-box .form-select { width: 100%; height: auto; padding: 0; font-size: 16px; font-weight: 500; line-height: 1.6; letter-spacing: -0.03em; color: var(--fig-black); background-color: transparent; border: 0; border-radius: 0; }
.properties-hero-search-box .form-control:focus, .properties-hero-search-box .form-select:focus { box-shadow: none; }
.properties-hero-search-box .form-control::placeholder { color: var(--fig-black); opacity: 1; }
.properties-hero-search-box .nice-select { width: 100%; display: flex; align-items: center; padding-right: 32px; background-color: transparent; background-image: none; color: var(--fig-black); transition: all 0.2s ease-in-out; }
.properties-hero-search-box .nice-select span { width: 100%; overflow: hidden; text-overflow: ellipsis; }
.properties-hero-search-box .nice-select:after { width: 20px; height: 16px; opacity: 0.5; right: 0; margin-top: 0; background: var(--bs-form-select-bg-img) no-repeat center/contain; border: 0; transform: translateY(-50%) rotate(0deg); transform-origin: center; }
.properties-hero-search-box .nice-select.open:after { transform: translateY(-50%) rotate(180deg); }
.properties-hero-search-box .nice-select .list { min-width: 240px; background-color: #fff; border-radius: 8px; box-shadow: 0 10px 25px rgba(0, 0, 0, 0.1); margin-top: 8px; padding: 5px; }
.properties-hero-search-box .nice-select .option { font-size: 20px; line-height: 40px; min-height: 40px; padding-left: 15px; padding-right: 25px; border-radius: 5px; color: var(--fig-black); transition: all 0.2s; }
.properties-hero-search-box .nice-select .option:hover, .properties-hero-search-box .nice-select .option.focus, .properties-hero-search-box .nice-select .option.selected.focus { background-color: rgba(0, 0, 0, 0.06); color: var(--fig-black); font-weight: 600; }
.properties-hero-search-box .form-check { width: 100%; max-width: 100%; margin-bottom: 0; }
.properties-hero-search-box .form-check-input { width: 20px; height: 20px; margin-right: 10px; border-radius: 0; border: 1px solid var(--fig-black); background-color: var(--fig-white); flex-shrink: 0; }
.properties-hero-search-box .form-check-input:checked { background-color: var(--fig-blue); border-color: var(--fig-blue); }
.properties-hero-search-box .form-check-input:focus { box-shadow: none; border-color: var(--fig-black); }
.properties-hero-search-box .form-check-label { font-size: 12px; font-weight: 500; line-height: 1.23; padding-left: 30px !important; letter-spacing: -0.003em; color: var(--fig-black); margin-bottom: 0; }
.ph-search-btn { width: 70px; height: 70px; color: var(--fig-grey); background: var(--fig-black); border: 0; border-radius: 50%; cursor: pointer; transition: all 0.2s ease-in-out; }
.ph-search-icon { width: 32px; height: 32px; }
.ph-search-icon svg { width: 100%; height: 100%; }
.ph-search-btn span { font-size: 20px; font-weight: 500; line-height: 1.1; letter-spacing: -0.01em; }
.ph-search-btn:hover { color: var(--fig-black); background: var(--fig-grey); }
.ph-search-btn:hover .ph-search-icon svg circle, .ph-search-btn:hover .ph-search-icon svg path { stroke: var(--fig-black); }
.properties-hero-search-exclude .form-check-label::before { border: 1px solid #000; top: 4px; }
.properties-hero-search-exclude .form-check-label::after { top: 10px; left: 6px; }
/* ---- */
.property-listings-container { position: relative; z-index: 8; }
.featured-listings-heading { margin-bottom: 24px; }
.featured-listings-heading h2 { font-size: 25px; line-height: 1.35; letter-spacing: -0.01em; }
.featured-listings-left { width: 74.5%; }
.featured-listings-row { width: calc(100% + 24px); margin-left: -12px; margin-bottom: -24px; align-items: stretch; }
.featured-listings-col { width: 50%; padding: 0 12px; margin-bottom: 24px; display: flex; flex-direction: column; }
.featured-listings-card { flex: 1; display: flex; flex-wrap: wrap; align-items: stretch; }
.fl-card-img-box { width: 42%; position: relative; clip-path: polygon(calc(100% - 118px) 0%, 100% 95px, 100% 100%, 0% 100%, 0% 0%); align-self: stretch; }
.fl-card-img { width: 100%; height: 100%; }
.fl-card-img img { width: 100%; height: 100%; object-fit: cover; }
.fl-card-shape { width: 146px; height: 95px; position: absolute; top: 0; right: 0; --shape-color: #C4D981; }
.fl-card-shape::before { content: ''; position: absolute; inset: 0; clip-path: polygon(28px 0%, 100% 0%, 100% 100%, 0% 82px); background: rgba(0, 0, 0, 0.3); transform: translate(3px, 4px); z-index: 0; }
.fl-card-shape::after { content: ''; position: absolute; inset: 0; clip-path: polygon(28px 0%, 100% 0%, 100% 100%, 0% 82px); background: var(--shape-color); z-index: 1; }
.fl-card-content { width: 58%; background: var(--fig-green); color: var(--fig-white); padding: 16px; align-self: stretch; min-height: 0; }
.flc-tags { width: fit-content; padding: 10px; font-family: var(--fig-font-primary-alt); font-size: 10px; font-weight: 700; line-height: 1.1; letter-spacing: 0.005em; margin-bottom: 24px; color: inherit; background: rgba(196, 191, 182, 0.2); border-radius: 30px; }
.flc-type { font-family: var(--fig-font-primary-alt); font-size: 12px; font-weight: 700; line-height: 1.2; letter-spacing: 0.02em; margin-bottom: 10px; }
.flc-title { font-size: 18px; line-height: 1.5; letter-spacing: -0.01em; margin-bottom: 4px; }
.flc-location { font-size: 12px; margin-bottom: 10px; }
.flc-size { font-size: 12px; font-weight: 500; line-height: 1; letter-spacing: 0; margin-bottom: 14px; }
.flc-units { font-size: 12px; font-weight: 500; line-height: 1; letter-spacing: 0; margin-bottom: 24px; }
.flc-actions-left .btn { padding: 14px 14px; }
.share-btn { position: relative; width: 100%; height: 100%; display: inline-flex; align-items: center; justify-content: center; padding: 15px 19px; border: 1px transparent; transition: var(--fig-custom-ease); }
.share-btn-icon { width: 16px; height: 16px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: var(--fig-custom-ease); }
.share-btn-icon img { width: 100%; height: 100%; object-fit: contain; }
.share-btn.black { background-color: var(--fig-black); border-color: var(--fig-black); }
.share-btn.black:hover { background-color: var(--fig-grey); border-color: var(--fig-black); }
.share-btn.black:hover .share-btn-icon { filter: brightness(1) invert(1); }
.share-btn.grey { background-color: var(--fig-grey); border-color: var(--fig-grey); }
.share-btn.grey:hover { background-color: var(--fig-black); border-color: var(--fig-grey); }
.share-btn.grey:hover .share-btn-icon { filter: brightness(1) invert(1); }
.share-btn-tooltip { position: absolute; right: 0; bottom: 44px; background: #111; color: #fff; font-size: 12px; padding: 6px 8px; border-radius: 4px; white-space: nowrap; opacity: 0; pointer-events: none; transition: opacity 0.2s ease; }
.share-btn-tooltip.is-visible { opacity: 1; }
.featured-listings-right { width: 25.5%; padding-left: 24px; }
.fl-map-box { width: 100%; height: 100%; position: relative; }
.fl-map-bg { width: 100%; height: 100%; position: absolute; inset: 0; }
.fl-map-bg img { width: 100%; height: 100%; object-fit: cover; }
.fl-map-box-inner { position: absolute; inset: 0; z-index: 1; width: 100%; height: 100%; }
.fl-map-content { padding: 16px; position: relative; z-index: 9; pointer-events: none; /* allow map to receive drag/pan; CTA re-enables below */ }
.fl-map-content .fl-map-cta,
.fl-map-content .fl-map-cta .btn { pointer-events: auto; }
/* Left-align CTA when used on single-property (property_id passed) */
.fl-map-cta--left { align-self: flex-start; margin-left: 0; margin-right: auto; }
/* ---- */
.properties-listing-results { margin-bottom: 32px; }
.property-card-list { width: calc(100% + 24px); margin-left: -12px; margin-bottom: -24px; }
.property-card-item { width: 25%; padding: 0 12px; margin-bottom: 24px; }
.property-card { width: 100%; height: 100%; }
.property-card-img-box { position: relative; clip-path: polygon(calc(100% - 84px) 0%, 100% 70px, 100% 100%, 0% 100%, 0% 0%); }
.property-card-overlay { width: 100%; height: 100%; position: absolute; inset: 0; padding: 16px; background: rgba(0, 0, 0, 0.4); }
.pc-overlay-text { font-family: var(--fig-font-primary-alt); font-size: 12px; font-weight: 700; line-height: 1.2; letter-spacing: 0.02em; color: var(--fig-grey-light); }
.property-card-shape { width: 104px; height: 70px; position: absolute; top: 0; right: 0; --shape-color: #C4D981; }
.property-card-shape::before { content: ''; position: absolute; inset: 0; clip-path: polygon(22px 0%, 100% 0%, 100% 100%, 0% 64px); background: rgba(0, 0, 0, 0.3); transform: translate(3px, 4px); z-index: 0; }
.property-card-shape::after { content: ''; position: absolute; inset: 0; clip-path: polygon(22px 0%, 100% 0%, 100% 100%, 0% 63px); background: var(--shape-color); z-index: 1; }
.property-card-img { width: 100%; height: 172px; background: #333; }
.property-card-img img { width: 100%; height: 100%; object-fit: cover; }
.property-card-content { padding: 16px; color: var(--fig-black); background: rgba(196, 191, 182, 0.2); }
.pc-tags { width: fit-content; padding: 10px; font-family: var(--fig-font-primary-alt); font-size: 10px; font-weight: 700; line-height: 1.1; letter-spacing: 0.005em; margin-bottom: 24px; color: inherit; background: rgba(196, 191, 182, 0.2); border-radius: 30px; }
.pc-type { font-family: var(--fig-font-primary-alt); font-size: 12px; font-weight: 700; line-height: 1.2; letter-spacing: 0.02em; margin-bottom: 10px; }
.pc-title { font-size: 18px; line-height: 1.5; letter-spacing: -0.01em; margin-bottom: 4px; }
.pc-location { font-size: 12px; margin-bottom: 10px; }
.pc-size { font-size: 12px; font-weight: 500; line-height: 1; letter-spacing: 0; margin-bottom: 24px; }
/* ---- */
.search-pagination-wrapper { margin-top: 80px; }
.page-pagination { gap: 18px; }
.page-pagination .page-numbers { width: 58px; height: 58px; display: flex; align-items: center; justify-content: center; padding: 21px; font-family: var(--fig-font-primary-alt); font-size: 16px; font-weight: 700; line-height: 1.1; letter-spacing: 0.005em; color: inherit; background: transparent; border: 1px solid transparent; }
.page-pagination .page-numbers.current { border-color: var(--fig-green); }
.prev.page-numbers, .next.page-numbers { background: var(--fig-grey); position: relative; font-size: 0; }
.prev.page-numbers:hover, .next.page-numbers:hover { background: var(--fig-black); }
.prev.page-numbers:hover:before, .next.page-numbers:hover:before { filter: brightness(0) invert(1); }
.prev.page-numbers:before, .next.page-numbers:before { content: ''; position: absolute; left: 0; top: 0; width: 100%; height: 100%; }
.prev.page-numbers:before { background: url(assets/images/swiper-arrow-left.svg) no-repeat center/20px; }
.next.page-numbers:before { background: url(assets/images/swiper-arrow-right.svg) no-repeat center/20px; }
/* ==================== Properties Search Page End ====================  */
/* ==================== Property Single Page Start ==================== */
.property-single-hero-content { padding: 184px 0 80px; color: var(--fig-grey-light); }
.property-single-hero-bg { width: 100%; height: 100%; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: var(--fig-green); }
.property-single-hero-bg img { width: 100%; height: 100%; object-fit: cover; }
.property-single-hero-heading h1 { font-size: 70px; margin-bottom: 38px; }
.ps-hero-date { font-size: 30px; font-weight: 500; line-height: 1.1; letter-spacing: -0.03em; margin-bottom: 18px; }
.psh-category-list { gap: 30px; }
.psh-category-list li a { font-size: 20px; font-weight: 500; line-height: 1.5; letter-spacing: -0.01em; color: var(--fig-grey-light); text-underline-offset: 2px; }
.psh-category-list li a:hover { text-decoration: underline; color: var(--fig-grey-light); }
.psh-back-link { gap: 18px; font-family: var(--fig-font-primary-alt); font-size: 12px; font-weight: 700; line-height: 1.1; letter-spacing: 0.005em; }
.link-icon { width: 16px; height: 16px; }
.link-icon img { width: 100%; height: 100%; object-fit: contain; }
.psh-back-link strong { color: var(--fig-grey); text-decoration: none; }
.psh-back-link:hover strong { text-decoration: underline; }
.psh-tags { width: fit-content; padding: 16px 28px; font-family: var(--fig-font-primary-alt); font-size: 12px; font-weight: 700; line-height: 1.6; letter-spacing: -0.003em; margin-bottom: 18px; color: var(--fig-grey); background: rgba(196, 191, 182, 0.2); border-radius: 30px; }
.psh-title { font-size: 70px; line-height: 1.1; letter-spacing: -0.03em; margin-bottom: 18px; }
.psh-size { font-size: 30px; font-weight: 500; line-height: 1.1; letter-spacing: -0.03em; margin-bottom: 18px; }
.psh-location { font-size: 20px; font-weight: 500; line-height: 1.5; letter-spacing: -0.01em; }
.psh-btn { padding: 14px 28px; font-family: var(--fig-font-primary-alt); font-size: 14px; font-weight: 700; line-height: 1.1; letter-spacing: 0.005em; text-align: center; color: var(--fig-black); background: var(--fig-grey-light); border: 2px solid var(--fig-grey-light); border-radius: 100px; transition: var(--fig-custom-ease); }
.psh-btn:hover { color: var(--fig-grey-light); background: transparent; }
.psh-btn.btn-outline { color: var(--fig-grey-light); background: transparent; }
.psh-btn.btn-outline:hover { color: var(--fig-black); background: var(--fig-grey-light); }
.property-single-hero-img { width: 100%; height: 100%; background: var(--fig-green); }
.property-single-hero-img img { width: 100%; height: 100%; object-fit: cover; }
.property-single-hero-quarter-circle { width: auto; height: 92%; position: absolute; top: 0; left: 0; }
.property-single-hero-quarter-circle img { width: 100%; height: 100%; object-fit: contain; }
.property-single-hero-lines { width: 100%; height: 100%; position: absolute; top: -158px; right: 0; transform: rotate(-44.95deg); transform-origin: top right; }
.property-single-hero-line { width: 100%; height: 1px; position: absolute; top: 0; right: 0; background: var(--fig-grey); opacity: 0.3; }
.property-single-hero-dashed-line { width: 100vw; height: 1px; position: absolute; top: 0; right: 470px; background-image: linear-gradient(90deg, var(--fig-grey), var(--fig-grey) 60%, transparent 60%, transparent 100%); background-size: 20px 1px; opacity: 0.3; transform: rotate(-89.75deg); transform-origin: top right; }
/* ---- */
.property-gallery-wrapper { height: 672px; gap: 5px; }
.property-gallery-left { width: 83.5%; height: 100%; }
.property-gallery-main { height: 100%; }
.property-gallery-main .swiper { height: 100%; }
.property-gallery-main .swiper-slide { height: 100%; }
.pg-main-img { width: 100%; height: 100%; }
.pg-main-img img { width: 100%; height: 100%; object-fit: cover; }
.property-gallery-right { width: 16.5%; height: 100%; }
.property-gallery-container--single .property-gallery-left { width: 100%; }
.property-gallery-container--single .property-gallery-right { display: none; }
.property-gallery-thumb { height: 100%; }
.property-gallery-thumb .swiper { height: 100%; }
.pg-thumb-img { width: 100%; height: 100%; opacity: 50%; }
.pg-thumb-img img { width: 100%; height: 100%; object-fit: cover; }
.property-gallery-thumb .swiper-slide { cursor: pointer; }
.property-gallery-thumb .swiper-slide-thumb-active .pg-thumb-img { opacity: 100%; }
.property-gallery-nav-holder { width: 134px; height: 58px; position: absolute; bottom: 40px; right: 40px; z-index: 9999; }
/* ---- */
.psd-content { width: calc(100% - 348px); padding-right: 6.25%; }
.psd-sidebar { width: 348px; position: sticky; top: 100px; }
.psd-enquire-card { padding: 32px; background-color: rgba(196, 191, 182, 0.2); }
.psd-enquire-card h3 { font-size: 25px; line-height: 1.35; letter-spacing: -0.01; }
.psd-enquire-card .btn { font-size: 12px; }
.psd-refer-card { padding: 32px 26px 32px 32px; }
.psd-refer-card h3 { font-size: 25px; line-height: 1.35; letter-spacing: -0.01; margin-bottom: 12px; }
.psd-content-row h2 { font-size: 50px; margin-bottom: 32px }
.psd-content-divider { width: 100%; height: 1px; background: var(--fig-green); margin: 80px 0; }
.modal-backdrop { --bs-backdrop-zindex: 9999; }
.modal { --bs-modal-zindex: 999991; }
.custom-modal .modal-dialog { max-width: 600px; }
.custom-modal .modal-close { position: absolute; right: 20px; top: 30px; border: none; background: transparent; width: 24px; height: 24px; display: flex; align-items: center; justify-content: center; z-index: 10; }
.custom-modal .modal-close img { width: 100%; height: 100%; object-fit: contain; }
.custom-modal .modal-content { border: none; border-radius: 0; }
.custom-modal .modal-body { padding: 20px; }
/* ---- */
.key-feature-list { width: calc(100% + 30px); margin-left: -15px; margin-bottom: -30px; }
.key-feature-item { width: 25%; padding: 0 15px; margin-bottom: 30px; }
.kfb-icon { width: 75px; height: 58px; margin: 0 auto 24px; }
.kfb-icon img { width: 100%; height: 100%; object-fit: contain; }
.kfb-text h3 { font-size: 15px; line-height: 1.6; font-weight: 400; margin-bottom: 0; }
/* ---- */
.location-left { width: calc(100% - 262px); padding-right: 30px; }
.location-map-box { width: 100%; height: 100%; min-height: 362px; }
.location-map-bg { width: 100%; height: 100%; position: absolute; inset: 0; }
.location-map-bg img { width: 100%; height: 100%; object-fit: cover; }
.location-map-content { padding: 16px; position: relative; z-index: 9; }
.location-map-cta .btn { font-size: 12px; }
.location-right { width: 262px; }
.location-right-head h3 { font-size: 20px; line-height: 1.5; letter-spacing: -0.01em; margin-bottom: 0; }
.location-right-head { margin-bottom: 24px; }
.location-accordion .accordion-item { border: none; background: transparent; border-bottom: 1px solid var(--fig-green); border-radius: 0; }
.location-accordion .accordion-item:first-child { border-top: 1px solid var(--fig-green); }
.location-accordion .accordion-button { background: transparent; box-shadow: none; padding: 16px 36px 16px 0; }
.location-accordion .accordion-button:focus { box-shadow: none; outline: none; }
.location-accordion .accordion-button::after { position: absolute; top: 50%; right: 5px; background-image: url(assets/images/location-accordion-arrow.svg); background-repeat: no-repeat; background-size: contain; background-position: center; width: 13px; height: 8px; transition: transform 0.3s ease; transform: translateY(-50%); }
.location-accordion .accordion-button:not(.collapsed)::after { transform: translateY(-50%) rotate(180deg); }
.location-accordion .accordion-button h4 { font-size: 20px; line-height: 1.5; color: var(--fig-black); margin: 0; }
.location-accordion .accordion-body { font-size: 12px; padding: 0 0 24px; }
/* ---- */
.masterplan-left { width: 100%; }
.masterplan-right { width: 100%; padding-left: 0; margin-top: 30px; }
.ml-info-list { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; }
.ml-info-item { background-color: rgba(196, 191, 182, 0.2); padding: 6px 0 6px 14px;}
.mli-box-left { font-size: 10px; font-weight: 700; text-align: center;padding-bottom: 68px; }
.mli-box-right h3 { font-size: 16px; line-height: 1.35; margin-bottom: 0; }
.mli-box-right { font-weight: 400; }
.masterplan-slider-holder { margin-bottom: 30px; position: relative; }
.masterplan-slider-holder .masterplan-pagination { position: relative; margin-top: 16px; display: flex; justify-content: center; align-items: center; padding: 12px 0; background: var(--fig-green); }
.masterplan-slider-holder .masterplan-pagination .swiper-pagination-bullet { width: 10px; height: 10px; background: rgba(255, 255, 255, 0.5); }
.masterplan-slider-holder .masterplan-pagination .swiper-pagination-bullet-active { background: #fff; opacity: 1; }
.ms-main-img { padding-bottom: 68%; }
.ms-main-img img { max-width: 100%; max-height: 100%; object-fit: contain; }
.ms-thumb-img { padding-bottom: 100%; cursor: pointer; opacity: .5; }
.masterplan-thumb-slider .swiper-slide-thumb-active .ms-thumb-img { opacity: 1; }
.ms-thumb-img img { width: 100%; height: 100%; object-fit: cover; position: absolute; top: 0; left: 0; right: 0; bottom: 0; }
.masterslider-bottom-text { margin-top: 30px; }
.masterplan-right-img { clip-path: polygon(85% 0, 85% 43%, 100% 43%, 100% 100%, 43% 100%, 30% 86%, 15% 86%, 0 57%, 29% 0); padding-bottom: 117%; }
.masterplan-right-img img { width: 100%; height: 100%; object-fit: cover; position: absolute; top: 0; left: 0; right: 0; bottom: 0; }
.masterplan-cta { margin-top: 32px; }
.masterplan-slider-holder span { position: absolute; top: -14px; right: 0; padding: 10px; background: rgb(247 247 247 / 80%); font-size: 12px; font-weight: 500; z-index: 2; }
.masterplan-lightbox { cursor: zoom-in; position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; }
.gslide-media { margin: 0 80px; }
.gslide-media:has(iframe) { margin: 0; }
.gbtn { background: rgba(196, 190, 181, 0.5) !important; }
@media (max-width:767.98px) {
 .gslide-media { margin: 0 20px; }
.glightbox-clean .gprev, .glightbox-clean .gnext { top: 50%; transform: translateY(-50%); }
 }
/* ---- */
.related-properties-slider-holder { margin-top: 56px; }
.related-properties-slider .swiper-wrapper { align-items: stretch; }
.related-properties-slider .swiper-slide { max-width: 304px; width: calc(100% - 20px); height: auto; display: flex; }
.related-properties-slider .swiper-slide .property-card { width: 100%; height: 100%; min-height: 0; }
/* .related-properties-container .row > [class*="col-"] { display: flex; } */
.related-properties-container .row .property-card { width: 100%; height: 100%; min-height: 0; }
.related-properties-nav-holder { width: 134px; height: 58px; margin-top: 56px; }
@media (max-width: 1199.98px) {
    .related-properties-container .related-properties-slider-holder > .row > [class*="col-"] {
        margin-bottom: 24px;
    }
    .related-properties-container .related-properties-slider-holder > .row > [class*="col-"]:last-child {
        margin-bottom: 0;
    }
}
.property-contact-form { background: rgba(255, 255, 255, 0.4); }
.pc-form-left { width: 58.5%; }
.pc-form-box { padding: 32px; }
.pc-form-box h3 { font-size: 25px; line-height: 1.35; letter-spacing: -0.01em; }
.pc-form-right { width: 41.5%; position: relative; }
.pc-form-img { width: 100%; height: 100%; position: absolute; inset: 0; }
.pc-form-img img { width: 100%; height: 100%; object-fit: cover; }
/* ==================== Property Single Page End ====================  */
/* ========================================== 
! Large devices (desktops, less than 1200px)
=========================================== */
@media (max-width:1199.98px) {
 .navbar { height: 122px; }
.navbar-brand { width: 156px; }
.navbar-toggler { width: 56px; height: 56px; border-radius: 0; text-decoration: none; padding: 0; border: 0; background: transparent; margin: 0; position: absolute; right: 0; top: 50%; z-index: 999; transform: translateY(-50%); }
.navbar-toggler:not([class="collapsed"]), .navbar-toggler:not([class="collapsed"]):focus, .navbar-toggler:not([class="collapsed"]):hover { background: rgba(196, 191, 182, 0.2); box-shadow: none; border-radius: 50%; transition: var(--fig-custom-ease); }
.navbar-toggler.collapsed, .navbar-toggler.collapsed:focus, .navbar-toggler.collapsed:hover { background: transparent; border-radius: 0; }
body:not(.open-menu) .navbar-toggler.collapsed, body .navbar-toggler.collapsed:focus, body .navbar-toggler.collapsed:hover { background: var(--fig-black); }
.navbar-toggler .navbar-toggler-icon { position: relative; display: inline-block; width: 30px; height: 1px; color: #243238; text-indent: -55px; margin-top: 0; background: transparent !important; transition: var(--fig-custom-ease); -webkit-transition: var(-tst--fig-custom-easee); vertical-align: middle; }
.navbar-toggler .navbar-toggler-icon:before, .navbar-toggler .navbar-toggler-icon:after { content: ""; width: 30px; height: 1px; background: var(--fig-grey); position: absolute; left: 0; transition: var(--fig-custom-ease); }
.navbar-toggler.collapsed .navbar-toggler-icon { background: var(--fig-grey-light) !important; }
body:not(.fixed, .open-menu) .navbar-toggler.collapsed .navbar-toggler-icon { background: var(--fig-grey-light) !important; }
.navbar-toggler.collapsed .navbar-toggler-icon:before, .navbar-toggler.collapsed .navbar-toggler-icon:after { background: var(--fig-black); }
.navbar-toggler.collapsed .navbar-toggler-icon:before { background: var(--fig-grey-light); }
body:not(.fixed, .open-menu) .navbar-toggler.collapsed .navbar-toggler-icon:before { background: var(--fig-grey-light); }
.navbar-toggler.collapsed .navbar-toggler-icon:after { background: var(--fig-grey-light); }
body:not(.fixed, .open-menu) .navbar-toggler.collapsed .navbar-toggler-icon:after { background: var(--fig-grey-light); }
.navbar-toggler.collapsed .navbar-toggler-icon:before { top: -10px; -webkit-transform: rotateZ(0deg); -moz-transform: rotateZ(0deg); -ms-transform: rotateZ(0deg); -o-transform: rotateZ(0deg); transform: rotateZ(0deg); }
.navbar-toggler .navbar-toggler-icon:before { top: 0; -webkit-transform: rotateZ(45deg); -moz-transform: rotateZ(45deg); -ms-transform: rotateZ(45deg); -o-transform: rotateZ(45deg); transform: rotateZ(45deg); }
.navbar-toggler.collapsed .navbar-toggler-icon:after { bottom: -10px; -webkit-transform: rotateZ(0deg); -moz-transform: rotateZ(0deg); -ms-transform: rotateZ(0deg); -o-transform: rotateZ(0deg); transform: rotateZ(0deg); }
.navbar-toggler .navbar-toggler-icon:after { bottom: 0; -webkit-transform: rotateZ(-45deg); -moz-transform: rotateZ(-45deg); -ms-transform: rotateZ(-45deg); -o-transform: rotateZ(-45deg); transform: rotateZ(-45deg); }
.navbar-collapse, .navbar-collapse.collapsing { width: 100%; height: 100%; transform: translateX(100%); position: fixed; left: 0; bottom: 0; top: 0; background: var(--fig-black); padding: 0; z-index: 99; margin: 0; padding-top: 92px; border: 0; overflow-y: auto; display: block !important; transition: var(--fig-custom-ease); }
.navbar .collapse.show { transform: none; }
.navbar-inside { height: 100%; padding: 0; overflow: hidden; overflow-y: auto; display: flex; flex-flow: column; align-items: center; }
.navbar-expand-xl .navbar-nav { width: 100%; padding: 18px 0; }
.navbar-expand-xl .navbar-nav .nav-item { width: 100%; padding: 12px 12px; margin: 0; transition: var(--fig-custom-ease); }
.navbar-expand-xl .navbar-nav .nav-link { font-size: 20px; line-height: 1.1; letter-spacing: 0.005em; padding: 0; position: relative; color: var(--fig-grey-light); }
.navbar-expand-xl .navbar-nav .nav-item:hover > .nav-link, .navbar-expand-xl .navbar-nav .nav-item.active > .nav-link { color: var(--tst-blue); }
.navbar-expand-xl .navbar-nav .dropdown-menu { background: transparent; border: 0; padding: 0; margin: 0 !important; }
.navbar-expand-xl .navbar-nav .dropdown-menu li { margin: 0; margin-top: 8px; padding: 0; }
.navbar-expand-xl .navbar-nav .dropdown-menu li:first-child { margin-top: 10px; }
.navbar-expand-xl .navbar-nav .dropdown-menu .dropdown-item { padding: 0; font-size: 18px; font-weight: 500; line-height: 1.6; color: var(--fig-grey-light); opacity: 0.6; }
.navbar-expand-xl .navbar-nav .dropdown-menu .dropdown-item:focus, .navbar-expand-xl .navbar-nav .dropdown-menu .dropdown-item:hover, .navbar-expand-xl .navbar-nav .dropdown-menu .dropdown-item.active { opacity: 1; background: transparent; }
.navbar-expand-xl .navbar-nav .dropdown > .nav-link::after { content: ""; display: inline-block; width: 15px; height: 18px; margin-left: 8px; }
.navbar-inside-bottom { width: 100%; padding: 0 12px 38px; }
.navbar-inside-bottom .btn { padding: 22px 30px; background-color: var(--fig-grey); color: var(--fig-black); border-color: var(--fig-grey); }
.navbar-inside-bottom .btn:hover { background-color: transparent; color: var(--fig-grey); border-color: var(--fig-grey); }
.search-box { position: relative; margin-bottom: 16px; }
.search-box .form-control, .search-box .form-control:focus { width: 100%; height: 60px; padding: 20.5px 25px; padding-right: 60px; font-family: var(--fig-font-primary-alt); font-size: 14px; font-weight: 700; line-height: 1; letter-spacing: 0.005em; color: var(--fig-grey); background: transparent; border: 1px solid var(--fig-grey); border-radius: 0; box-shadow: none; }
.search-box .form-control:focus { color: var(--fig-black); background-color: var(--fig-grey-light); border-color: var(--fig-grey); }
.search-box .form-control::placeholder { color: var(--fig-grey); opacity: 1; }
.search-box button { width: 60px; height: 60px; position: absolute; right: 0; top: 0; bottom: 0; background: transparent; border: 0; }
/* Blog Single Page */
.blog-single-hero-heading h1 { font-size: 60px; }
.job-single-hero-heading h1 { font-size: 60px; }
.error-container h1 { font-size: 60px; }
.search-results-container h1 { font-size: 60px; }
.standard-container .standard-page-title { font-size: 60px; }
/* ==================== Properties Search Page ==================== */
.property-hero-content h1 { font-size: 60px; }
.properties-hero-search-postcode, .properties-hero-search-name, .properties-hero-search-type, .properties-hero-search-size { width: 100%; }
.properties-hero-search-postcode, .properties-hero-search-name, .properties-hero-search-type, .properties-hero-search-size { max-width: 100%; padding: 16px 28px 10px 44px; background: rgba(196, 191, 182, 0.7); border-radius: 90px; border: none; }
.properties-hero-search-exclude { width: 100%; display: flex; align-items: center; justify-content: center; }
.properties-hero-search-postcode .form-label, .properties-hero-search-name .form-label, .properties-hero-search-type .form-label, .properties-hero-search-size .form-label { line-height: 1.1; letter-spacing: -0.01em; }
.properties-hero-search-wrapper { bottom: -36px; margin-top: 16px; }
.properties-hero-search-box { padding: 0; background: transparent; border-radius: 0; backdrop-filter: none; display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
.properties-hero-search-box .form-control, .properties-hero-search-box .form-select { width: 100%; font-size: 20px; }
.ph-search-btn-wrap { width: 100%; }
.ph-search-btn { width: 100%; border-radius: 90px; }
/* ---- */
.featured-listings-left { width: 100%; }
.featured-listings-right { width: 100%; padding-left: 0; margin-top: 24px; }
.fl-map-box { min-height: 400px; }
/* ---- */
.property-card-item { width: 33.33%; }
/* ---- */
.psh-title { font-size: 60px; }
/* ---- */
.ml-info-list { grid-template-columns: repeat(3, 1fr); }
/* ==================== Properties Search Page ==================== */ }
/*==========================================
! Medium devices (tablets, less than 992px)
========================================== */
@media (max-width:991.98px) {
.content-container { padding: 80px 0; }
.footer-cta { padding: 120px 0 100px; }
.footer-cta-left h3 { font-size: 40px; }
.footer-main { padding: 100px 0 10px; }
.footer-col h4 { font-size: 20px; }
.copyright { margin-top: 100px; }
/* Blog Single Page */
.blog-single-hero-content { padding: 160px 0 65px; }
.blog-single-hero-heading h1 { font-size: 50px; }
.no-module-container, .error-container, .standard-container, .search-results-container { padding-top: 160px !important; }
.error-container h1 { font-size: 50px; }
.search-results-container h1 { font-size: 50px; }
.standard-container .standard-page-title { font-size: 50px; }
.job-single-hero-content { padding: 160px 0 65px; }
.job-single-hero-heading h1 { font-size: 60px; }
/* ==================== Properties Search Page ==================== */
.properties-hero-container { padding: 160px 0 0; }
.property-hero-content h1 { font-size: 50px; }
.properties-hero-search-holder { margin-top: 50px; }
/* ---- */
.fl-card-img-box { width: 100%; order: -1; clip-path: polygon(calc(100% - 90px) 0%, 100% 72px, 100% 100%, 0% 100%, 0% 0%); }
.fl-card-img { height: 172px; }
.fl-card-shape { width: 112px; height: 72px; clip-path: polygon(22px 0%, 100% 0%, 100% 100%, 0% 64px); filter: drop-shadow(2px 4px 8px rgba(0, 0, 0, 0.25)); }
.fl-card-content { width: 100%; }
/* ---- */
.property-card-item { width: 50%; }
/* ---- */
.psh-title { font-size: 50px; }
/* ---- */
.psd-content-row h2 { font-size: 40px; margin-bottom: 32px }
.psd-content-divider { margin: 60px 0; }
/* ---- */
.property-gallery-wrapper { height: auto; }
.property-gallery-left { width: 100%; height: 400px; }
.property-gallery-right { width: 100%; height: 100px; }
.property-gallery-thumb .swiper-slide { height: 100%; width: 20%; }
/* ---- */
.psd-content { width: 100%; padding-right: 0; }
.psd-sidebar { width: 100%; position: static; top: 0; margin-top: 60px; }
/* ---- */
.location-left { width: 100%; padding-right: 0; margin-bottom: 30px; }
.location-right { width: 100%; }
.location-map-box { min-height: 308px; }
.location-right-head { margin-bottom: 30px; }
/* ==================== Properties Search Page ==================== */ }
/* =================================================  
! Small devices (landscape phones, less than 768px)
================================================= */
@media (max-width:767.98px) {
 .content-container { padding: 60px 0; }
.ml-info-list { grid-template-columns: repeat(2, 1fr); }
.heading .title { font-size: 30px; }
.footer-lines { top: 59.5%; }
.footer-line.line-2 { bottom: initial; top: 0; }
.footer-dashed-line.line-1 { width: 200vw; bottom: initial; top: 0; left: 100%; transform: rotate(227.5deg); transform-origin: top left; }
.footer-dashed-line.line-2 { width: 200vw; left: 100%; transform: rotate(130deg); }
.footer-cta { padding: 83px 0 69px; border-bottom: 0; }
.footer-cta-left { margin-bottom: 30px; }
.footer-cta-left h3 { font-size: 30px; }
.footer-shape { top: -27px; }
.footer-main { padding: 0 0 34px; }
.footer-logo { margin-bottom: 59px; }
.footer-nav-wrapper { gap: 64px 30px; }
.footer-col { width: calc(50% - 15px); max-width: 50%; }
.footer-col h4 { font-size: 15px; }
.social-links { margin-top: 16px; }
.footer-contact-item { font-size: 13px; }
.copyright { font-size: 12px; margin-top: 22px; }
/* GLOBAL SWIPER ARROW */
.custom-slider-navigation { margin-top: 30px; }
/* Read More Css */
.read-more-content { font-size: 20px; }
/* Read More Css */
.top-shape { height: 38px; }
.bottom-shape { height: 38px; }
.half-top-shape { bottom: calc(100% - 182px); clip-path: polygon(0% 100%, 100% calc(100% - 50px), 100% 0%, 0% 0%); }
.half-bottom-shape { top: 217px; clip-path: polygon(0% 100%, 100% 100%, 100% 38px, 0% 0%); }
/* Blog Single Page */
.blog-single-hero-heading h1 { font-size: 35px; margin-bottom: 30px; }
.bs-hero-date { margin-bottom: 24px; }
.bsh-category-list { max-width: 230px; gap: 6px 10px; margin: 0 auto; }
.bsh-category-list li a { font-size: 15px; }
.blog-single-hero-quarter-circle { width: 100%; height: auto; position: absolute; bottom: initial; top: 55.75%; transform: translateY(-50%); }
.blog-single-intro-content { font-size: 20px; line-height: 1.1; }
.blog-single-content p:has(img):not(:last-child) { margin-bottom: 30px; }
.blog-single-content h2, .blog-single-content h3 { font-size: 30px; }
.blog-single-content h4 { font-size: 28px; }
.blog-single-content h5 { font-size: 24px; }
.blog-single-content h6 { font-size: 20px; }
.blog-single-cta a.btn { width: 100%; }
.error-container h1 { font-size: 35px; }
.search-results-container h1 { font-size: 35px; }
.standard-container .standard-page-title { font-size: 35px; margin-bottom: 30px; }
.standard-container h2, .standard-container h3 { font-size: 30px; }
.standard-container h4 { font-size: 28px; }
.standard-container h5 { font-size: 24px; }
.standard-container h6 { font-size: 20px; }
.job-single-hero-heading h1 { font-size: 35px; margin-bottom: 30px; }
.js-hero-location { font-size: 25px; }
.js-hero-job-type { font-size: 15px; }
.job-single-content h2, .job-single-content h3 { font-size: 30px; }
.job-single-content h4 { font-size: 28px; }
.job-single-content h5 { font-size: 24px; }
.job-single-content h6 { font-size: 20px; }
/* ==================== Properties Search Page ==================== */
.properties-hero-search-holder { margin-top: 30px; }
.properties-hero-search-box { grid-template-columns: 1fr; }
.property-hero-content h1 { font-size: 35px; }
.page-pagination { gap: 6px; }
.page-pagination .page-numbers { width: 40px; height: 40px; }
/* ---- */
.psh-title { font-size: 35px; }
.psh-size { font-size: 25px; }
.psh-location { font-size: 16px; }
/* ---- */
.psd-content-row h2 { font-size: 30px; margin-bottom: 32px }
.psd-content-divider { margin: 40px 0; }
/* ---- */
.key-feature-item { width: 33.33%; }
/* ---- */
.related-properties-slider-holder { margin-top: 40px; }
.related-properties-nav-holder { margin-top: 40px; }
/* ==================== Properties Search Page ==================== */ }
/* ======================================================
! Extra small devices (portrait phones, less than 576px)
====================================================== */
@media (max-width:575.98px) {
 /* ==================== Properties Search Page ==================== */
.ml-info-list { grid-template-columns: repeat(2, 1fr); }
.featured-listings-col { width: 100%; }
.property-card-item { width: 100%; }
.key-feature-item { width: 50%; }
.pc-form-left { width: 100%; }
.pc-form-right { width: 100%; }
.pc-form-img { height: 300px; position: relative; inset: auto; }
/* ==================== Properties Search Page ==================== */ }
.downloadable-files-row {
    display: grid;
    gap: 16px;
    margin: 30px 0;
    grid-template-columns: 1;
}

.downloadable-files-row  a.downloadable-file-link {
    width: 100%;
    max-width: none;
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 18px 22px;
    background: #fff;
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-radius: 12px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.06);
    text-decoration: none;
    color: var(--text-color);
}

.downloadable-files-row  a.downloadable-file-link:hover {
    border-color: var(--fig-green);
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.1);
    color: var(--fig-white);
    background-color: var(--fig-green);
}

.downloadable-files-row  a.downloadable-file-link img {
    width: 50px;
    flex: 0 0 auto;
}

.downloadable-files-row  a.downloadable-file-link p {
    margin: 0;
    font-weight: 600;
    line-height: 1.4;
}