/*!
Theme Name: so
Theme URI: https://somarketing.com/
Author: somarketing.com
Author URI: https://somarketing.com/
Description: A custom theme by So Marketing
Version: 1.0.0
Tested up to: 6.0
Requires PHP: 7.4
Text Domain: so
*/
/*! tailwindcss v3.2.4 | MIT License | https://tailwindcss.com*/
*,
:after,
:before {
    box-sizing: border-box;
    border: 0 solid #e5e7eb
}

:after,
:before {
    --tw-content: ""
}

html {
    line-height: 1.5;
    -webkit-text-size-adjust: 100%;
    -moz-tab-size: 4;
    -o-tab-size: 4;
    tab-size: 4;
    font-family: Source Sans Pro, Arial, Helvetica, sans-serif;
    font-feature-settings: normal
}

body {
    margin: 0;
    line-height: inherit
}

hr {
    height: 0;
    color: inherit;
    border-top-width: 1px
}

abbr:where([title]) {
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-size: inherit;
    font-weight: inherit
}

a {
    color: inherit;
    text-decoration: inherit
}

b,
strong {
    font-weight: bolder
}

code,
kbd,
pre,
samp {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, Liberation Mono, Courier New, monospace;
    font-size: 1em
}

small {
    font-size: 80%
}

sub,
sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: initial
}

sub {
    bottom: -.25em
}

sup {
    top: -.5em
}

table {
    text-indent: 0;
    border-color: inherit;
    border-collapse: collapse
}

button,
input,
optgroup,
select,
textarea {
    font-family: inherit;
    font-size: 100%;
    font-weight: inherit;
    line-height: inherit;
    color: inherit;
    margin: 0;
    padding: 0
}

button,
select {
    text-transform: none
}

[type=button],
[type=reset],
[type=submit],
button {
    -webkit-appearance: button;
    background-color: initial;
    background-image: none
}

:-moz-focusring {
    outline: auto
}

:-moz-ui-invalid {
    box-shadow: none
}

progress {
    vertical-align: initial
}

::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
    height: auto
}

[type=search] {
    -webkit-appearance: textfield;
    outline-offset: -2px
}

::-webkit-search-decoration {
    -webkit-appearance: none
}

::-webkit-file-upload-button {
    -webkit-appearance: button;
    font: inherit
}

summary {
    display: list-item
}

blockquote,
dd,
dl,
figure,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
p,
pre {
    margin: 0
}

fieldset {
    margin: 0
}

fieldset,
legend {
    padding: 0
}

menu,
ol,
ul {
    list-style: none;
    margin: 0;
    padding: 0
}

textarea {
    resize: vertical
}

input::-moz-placeholder,
textarea::-moz-placeholder {
    opacity: 1;
    color: #9ca3af
}

input::placeholder,
textarea::placeholder {
    opacity: 1;
    color: #9ca3af
}

[role=button],
button {
    cursor: pointer
}

:disabled {
    cursor: default
}

audio,
canvas,
embed,
iframe,
img,
object,
svg,
video {
    display: block;
    vertical-align: middle
}

img,
video {
    max-width: 100%;
    height: auto
}

[hidden] {
    display: none
}

*,
::backdrop,
:after,
:before {
    --tw-border-spacing-x: 0;
    --tw-border-spacing-y: 0;
    --tw-translate-x: 0;
    --tw-translate-y: 0;
    --tw-rotate: 0;
    --tw-skew-x: 0;
    --tw-skew-y: 0;
    --tw-scale-x: 1;
    --tw-scale-y: 1;
    --tw-pan-x: ;
    --tw-pan-y: ;
    --tw-pinch-zoom: ;
    --tw-scroll-snap-strictness: proximity;
    --tw-ordinal: ;
    --tw-slashed-zero: ;
    --tw-numeric-figure: ;
    --tw-numeric-spacing: ;
    --tw-numeric-fraction: ;
    --tw-ring-inset: ;
    --tw-ring-offset-width: 0px;
    --tw-ring-offset-color: #fff;
    --tw-ring-color: #3b82f680;
    --tw-ring-offset-shadow: 0 0 #0000;
    --tw-ring-shadow: 0 0 #0000;
    --tw-shadow: 0 0 #0000;
    --tw-shadow-colored: 0 0 #0000;
    --tw-blur: ;
    --tw-brightness: ;
    --tw-contrast: ;
    --tw-grayscale: ;
    --tw-hue-rotate: ;
    --tw-invert: ;
    --tw-saturate: ;
    --tw-sepia: ;
    --tw-drop-shadow: ;
    --tw-backdrop-blur: ;
    --tw-backdrop-brightness: ;
    --tw-backdrop-contrast: ;
    --tw-backdrop-grayscale: ;
    --tw-backdrop-hue-rotate: ;
    --tw-backdrop-invert: ;
    --tw-backdrop-opacity: ;
    --tw-backdrop-saturate: ;
    --tw-backdrop-sepia:
}

/* !ATTENTION! */
:root {
    --black: #000;
    --black-light: #484848;
    --black-alpha: #000000bf;
    --white: #fff;
    --white-light: #e8e8e8;
    --white-alpha: #ffffffbf;
    --yellow: #f7ec53;
    --gray: #484848;
    --gray-light: #e8e8e8;
}

body,
html {
    position: relative;
    height: 100%;
    width: 100%;
    overflow: hidden;
    scroll-behavior: smooth;
}

body {
    overflow-x: hidden;
    overflow-y: scroll;
    --tw-bg-opacity: 1;
    background-color: rgb(255 255 255 / var(--tw-bg-opacity));
    --tw-text-opacity: 1;
    color: rgb(34 34 34 / var(--tw-text-opacity));
    font-family: brandon-grotesque;
}

#content,
#main,
#page,
#primary,
article,
section {
    float: none;
    display: block;
    width: 100%;
}

.container,
.wp-block-heading {
    margin-left: auto;
    margin-right: auto;
    width: 92%;
    max-width: 1640px;
}

@media (min-width: 1300px) {

    .container,
    .wp-block-heading {
        width: 96%;
    }
}

.sticky {
    position: sticky;
}

.float-left {
    float: none;
}

.block {
    display: block;
}

.table {
    display: table;
}

.grid {
    display: grid;
}

.hidden {
    display: none;
}

.h-2 {
    height: 0.5rem;
}

.w-full {
    width: 100%;
}

.transform {
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.filter {
    filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

#accreditations {
    float: none;
    display: block;
    width: 100%;
    padding-top: 5rem;
    padding-bottom: 3rem;
}

#accreditations ul {
    display: flex;
    list-style-type: none;
    flex-wrap: wrap;
    justify-content: center;
}

#accreditations li {
    margin-bottom: 4rem;
    width: 100%;
    padding-left: 2rem;
    padding-right: 2rem;
    text-align: center;
}

@media (min-width: 640px) {
    #accreditations li {
        width: 50%;
    }
}

@media (min-width: 1024px) {
    #accreditations li {
        width: 33.333333%;
    }
}

@media (min-width: 1300px) {
    #accreditations li {
        margin-bottom: 2rem;
        width: 25%;
    }
}

#accreditations li img {
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 1rem;
    height: 53px;
    width: auto;
}

#accreditations li span {
    padding-left: 2rem;
    padding-right: 2rem;
    font-size: 1.25rem;
    line-height: 1.75rem;
    --tw-text-opacity: 1;
}

#accreditations li span,
.animated-banner {
    display: block;
    font-weight: 700;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

.animated-banner {
    margin-left: auto;
    margin-right: auto;
    width: 100%;
    max-width: 1024px;
    border-width: 2px;
    --tw-border-opacity: 1;
    border-color: rgb(72 72 72 / var(--tw-border-opacity));
    padding: 1rem;
    font-size: 2.25rem;
    line-height: 2.5rem;
    --tw-text-opacity: 1;
}

.animated-banner-ctr {
    display: block;
    width: 100%;
    --tw-bg-opacity: 1;
    background-color: rgb(247 236 83 / var(--tw-bg-opacity));
}

.animated-banner-grid {
    overflow: hidden;
    width: 100%;
    white-space: nowrap;
}

.animated-banner-cell {
    display: inline-block;
    width: 100%;
    background: #020024;
    background: linear-gradient(90deg, var(--gray-light) 0, var(--gray-light) 80%, var(--yellow) 80%, var(--yellow) 100%);
    transition: all 0.6s cubic-bezier(0.76, 0, 0.24, 1);
}

.animated-banner .animated-banner-cell:last-child {
    background: #020024;
    background: linear-gradient(90deg, var(--gray-light) 0, var(--gray-light) 20%, var(--yellow) 20%, var(--yellow) 100%);
}

.animated-banner:hover .animated-banner-cell {
    transform: translateX(calc(-100% - 8px));
}

.animated-banner-cell span {
    display: block;
    text-align: right;
    padding-right: calc(20% + 50px);
}

.animated-banner .animated-banner-cell:last-child span {
    text-align: left;
    padding-left: calc(20% + 50px);
}

.animated-banner-content {
    position: relative;
    padding: 2rem;
}

.animated-banner-icon {
    right: calc(20% - 40px);
}

.animated-banner-cell:last-child .animated-banner-icon,
.animated-banner-icon {
    position: absolute;
    top: 0;
    display: flex;
    width: 80px;
    height: 80px;
    transform: translateY(12px);
}

.animated-banner-cell:last-child .animated-banner-icon {
    right: auto;
    left: calc(20% - 40px);
}

.areas ul {
    margin-bottom: 2rem;
    display: block;
    display: grid;
    width: 100%;
    grid-template-columns: repeat(1, minmax(0, 1fr));
    gap: 2px;
}

@media (min-width: 640px) {
    .areas ul {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 2rem;
    }
}

@media (min-width: 768px) {
    .areas ul {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (min-width: 1024px) {
    .areas ul {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

.areas li {
    display: block;
    width: 100%;
    --tw-bg-opacity: 1;
    background-color: rgb(247 236 83 / var(--tw-bg-opacity));
    padding: 0.5rem;
}

@media (min-width: 768px) {
    .areas li {
        display: flex;
    }
}

.areas li>div {
    width: 100%;
}

.areas li>div a {
    display: block;
    width: 100%;
}

.areas li>span {
    display: block;
    width: 100%;
    padding: 0.5rem;
    font-size: 1.5rem;
    line-height: 2rem;
    font-weight: 700;
}

#awards,
.areas li>span {
    --tw-bg-opacity: 1;
    background-color: rgb(247 236 83 / var(--tw-bg-opacity));
}

#awards {
    padding-top: 5rem;
    padding-bottom: 5rem;
}

#awards h3 {
    display: block;
    width: 100%;
    font-size: 3.75rem;
    line-height: 1;
    font-weight: 700;
    text-transform: capitalize;
    line-height: 4rem;
}

#awards h3,
#awards p {
    margin-bottom: 2rem;
    text-align: center;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

#awards p {
    font-size: 1.125rem;
    line-height: 1.75rem;
}

#awards ul {
    display: grid;
    width: 100%;
    list-style-type: none;
    grid-template-columns: repeat(1, minmax(0, 1fr));
    gap: 1rem;
}

@media (min-width: 640px) {
    #awards ul {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (min-width: 1024px) {
    #awards ul {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

@media (min-width: 1300px) {
    #awards ul {
        grid-template-columns: repeat(6, minmax(0, 1fr));
    }
}

#awards li {
    display: block;
    display: flex;
    align-items: center;
    justify-content: center;
    --tw-bg-opacity: 1;
    background-color: rgb(255 255 255 / var(--tw-bg-opacity));
    padding: 1rem;
    text-align: center;
}

#awards li img {
    display: block;
    height: auto;
    width: 100%;
}

.banner {
    display: flex;
    width: 100%;
    align-items: center;
    justify-content: center;
    padding: 2rem;
}

.banner-title {
    display: block;
    padding: 2rem 4rem;
    text-align: center;
    font-size: 32px;
    font-weight: 700;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

#breadcrumbs {
    float: none;
    padding-top: 40px;
    padding-bottom: 40px;
}

#breadcrumbs,
#breadcrumbs ul {
    display: block;
    width: 100%;
}

#breadcrumbs li {
    display: inline-block;
    padding: 0.5rem;
    font-size: 1rem;
    line-height: 1.5rem;
}

#breadcrumbs li:last-child {
    --tw-bg-opacity: 1;
    background-color: rgb(247 236 83 / var(--tw-bg-opacity));
}

.comments-banner_title {
    margin-bottom: 1rem;
    --tw-bg-opacity: 1;
    background-color: rgb(247 236 83 / var(--tw-bg-opacity));
    padding: 2rem;
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 2.7rem;
}

.comments-banner_quote,
.comments-banner_title {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

.comments-banner_quote {
    font-size: 1.125rem;
    line-height: 1.75rem;
}

@media only screen and (min-width: 768px) {
    .comments-banner {
        display: grid;
        grid-template-columns: 1.2fr 0.8fr;
        grid-template-rows: 1fr;
        gap: 4rem;
        grid-auto-flow: row;
    }

    .comments-banner_title {
        margin-bottom: 0;
    }
}

#cont-form {
    --tw-bg-opacity: 1;
    background-color: rgb(247 236 83 / var(--tw-bg-opacity));
    padding-top: 5rem;
    padding-bottom: 5rem;
}

.cont-form-grid {
    width: 100%;
}

@media (min-width: 1024px) {
    .cont-form-grid {
        display: flex;
        gap: 5rem;
    }
}

.cont-form-col {
    width: 100%;
}

@media (min-width: 1024px) {
    .cont-form-col {
        width: 50%;
    }
}

.cont-form-hero {
    margin-bottom: 2rem;
    height: 160px;
    width: 100%;
}

.cont-form-title {
    margin-bottom: 2rem;
    display: block;
    width: 100%;
    font-size: 3.75rem;
    line-height: 1;
    font-weight: 700;
    text-transform: capitalize;
    line-height: 4rem;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

@media (min-width: 1300px) {
    .cont-form-title {
        padding-right: 20%;
    }
}

#cont-form p {
    margin-bottom: 2rem;
    font-size: 1.125rem;
    line-height: 1.75rem;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

#so-form-one {
    display: block;
    width: 100%;
}

#so-form-one input[type="email"],
#so-form-one input[type="tel"],
#so-form-one input[type="text"],
#so-form-one textarea {
    float: none;
    margin-bottom: 1rem;
    display: block;
    width: 100%;
    border-bottom-width: 2px;
    --tw-border-opacity: 1;
    border-color: rgb(72 72 72 / var(--tw-border-opacity));
    background-color: initial;
    padding-bottom: 0.5rem;
}

#so-form-one textarea {
    height: 200px;
}

#so-form-one ::-moz-placeholder {
    color: var(--grey);
    opacity: 1;
}

#so-form-one ::placeholder {
    color: var(--grey);
    opacity: 1;
}

#so-form-one :-ms-input-placeholder {
    color: var(--grey);
}

#so-form-one ::-ms-input-placeholder {
    color: var(--grey);
}

#so-form-one input[type="submit"] {
    border-radius: 2px;
    float: none;
    display: flex;
    height: 47px;
    width: 162px;
    align-items: center;
    justify-content: center;
    --tw-bg-opacity: 1;
    background-color: rgb(72 72 72 / var(--tw-bg-opacity));
    font-size: 1.25rem;
    line-height: 1.75rem;
    text-transform: uppercase;
    --tw-text-opacity: 1;
    color: rgb(255 255 255 / var(--tw-text-opacity));
}

#so-form-one input[type="submit"]:hover {
    --tw-text-opacity: 1;
    color: rgb(247 236 83 / var(--tw-text-opacity));
}

.cont_img-content,
.cont_img-grid,
.cont_img-img {
    display: block;
    float: none;
    width: 100%;
}

.cont_img.one .cont_img-grid div {
    width: 100%;
}

.cont_img.one .cont_img-content {
    display: block;
}

.cont_img-content a {
    text-decoration: underline;
}

.cont_img-content h2,
.cont_img-content h3,
.cont_img-content h4,
.cont_img-content h5,
.cont_img-content h6 {
    font-weight: 700;
    margin-bottom: 2rem;
}

.cont_img-content h2 {
    font-size: 32px;
}

.cont_img-content h3 {
    font-size: 28px;
}

.cont_img-content h4 {
    font-size: 26px;
}

.cont_img-content h5,
.cont_img-content h6 {
    font-size: 24px;
}

.cont_double .cont_img-content>div {
    width: 50%;
}

/*.cont_img-img {*/
/*    height: 200px;*/
/*}*/
.cont_img-content p {
    margin-bottom: 2rem;
    font-size: 1.125rem;
    line-height: 1.75rem;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

.cont_img-content ul {
    list-style: none;
    padding-left: 20px;
    list-style-type: none;
    margin-bottom: 2rem;
}

.cont_img-content li {
    position: relative;
    margin-bottom: 2rem;
    padding-left: 40px;
    font-size: 1.125rem;
    line-height: 1.75rem;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
    display: -webkit-flex;
    display: flex;
    align-items: center;
}

.cont_img-content li:last-child {
    margin-bottom: 0;
}

.cont_img-content li:before {
    content: "";
    width: 20px;
    height: 20px;
    line-height: 20px;
    position: absolute;
    left: 0;
    display: inline-block;
    border-radius: 9999px;
    --tw-bg-opacity: 1;
    background-color: rgb(247 236 83 / var(--tw-bg-opacity));
}

@media only screen and (min-width: 768px) and (max-width: 1024px) {
    html .quotes ul {
        grid-template-columns: 1fr;
    }

    html .quotes li {
        padding: 3rem 1.5rem;
    }

    html .cont-form-title,
    html #services h2,
    html #awards h3,
    html #latest-news h3,
    html .feature_grid-title {
        font-size: 3rem;
    }

    html .cat-nav li a {
        padding: 0.65rem;
    }

    html .cat-list ul {
        grid-template-columns: 1fr 1fr;
    }

    html .cont_img-grid {
        display: block;
        gap: 0;
    }

    html .cont_img-img {
        min-height: 200px;
    }

    html .cont_img-content {
        display: block;
    }
}

@media only screen and (min-width: 768px) {
    .cont_img-content {
        display: flex;
        gap: 4rem;
    }

    .cont_img-grid {
        display: grid;
        grid-template-columns: 0.8fr 1.2fr;
        grid-template-rows: 1fr;
        gap: 4rem;
        grid-auto-flow: row;
        grid-template-areas: "cont_img-content cont_img-img";
    }

    .cont_img-grid-reverse {
        grid-template-columns: 1.2fr 0.8fr;
        grid-template-areas: "cont_img-img cont_img-content";
    }

    .cont_img-content {
        grid-area: cont_img-content;
    }

    .cont_img-img {
        grid-area: cont_img-img;
        height: auto;
    }

    .cont_double {
        display: grid;
        grid-template-columns: 1.3fr 0.7fr;
        grid-template-rows: 1fr;
    }

    .cont_img-grid-reverse.cont_double {
        display: grid;
        grid-template-columns: 0.7fr 1.3fr;
        grid-template-rows: 1fr;
    }
}

.enquiry-grid {
    float: none;
    display: block;
    width: 100%;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

@media (min-width: 1024px) {
    .enquiry-grid {
        float: none;
        display: flex;
        gap: 2rem;
    }
}

@media (min-width: 1536px) {
    .enquiry-grid {
        gap: 4rem;
    }
}

.enquiry-grid .col-one {
    float: none;
    margin-bottom: 2rem;
    display: block;
    width: 100%;
}

@media (min-width: 1024px) {
    .enquiry-grid .col-one {
        margin-bottom: 0;
        width: 50%;
    }
}

@media (min-width: 1300px) {
    .enquiry-grid .col-one {
        width: 75%;
    }

    .enquiry-grid .col-one .enquiry-form {
        padding-left: 8rem;
        padding-right: 8rem;
        position: sticky;
        top: 75px;
    }
}

.enquiry-grid .col-two {
    float: none;
    display: block;
    width: 100%;
}

@media (min-width: 1024px) {
    .enquiry-grid .col-two {
        width: 50%;
    }
}

@media (min-width: 1300px) {
    .enquiry-grid .col-two {
        width: 25%;
    }
}

.enquiry-banner {
    background: url(../theme/assets/img/bg1.jpg) no-repeat 50%;
    background-size: cover;
    margin-bottom: 2rem;
}

.enquiry-banner .feature_grid-title {
    margin-bottom: 2rem;
}

.enquiry-banner,
.enquiry-banner span {
    display: flex;
    width: 100%;
    align-items: center;
    justify-content: center;
    padding: 2rem;
}

.enquiry-banner span {
    --tw-bg-opacity: 1;
    background-color: rgb(255 255 255 / var(--tw-bg-opacity));
    font-size: 2.25rem;
    line-height: 2.5rem;
    font-weight: 700;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

.enquiry-grid #so-form-one {
    font-size: 1rem;
    line-height: 1.5rem;
}

.enquiry-grid #so-form-one input[type="email"],
.enquiry-grid #so-form-one input[type="tel"],
.enquiry-grid #so-form-one input[type="text"],
.enquiry-grid #so-form-one textarea {
    --tw-border-opacity: 1;
    border-color: rgb(247 236 83 / var(--tw-border-opacity));
}

.enquiry-grid #so-form-one textarea {
    height: 200px;
}

.enquiry-grid #so-form-one ::-moz-placeholder {
    color: var(--grey);
    opacity: 1;
}

.enquiry-grid #so-form-one ::placeholder {
    color: var(--grey);
    opacity: 1;
}

.enquiry-grid #so-form-one :-ms-input-placeholder {
    color: var(--grey);
}

.enquiry-grid #so-form-one ::-ms-input-placeholder {
    color: var(--grey);
}

.enquiry-grid #so-form-one input[type="submit"] {
    border-radius: 2px;
    float: none;
    display: flex;
    height: 47px;
    width: 162px;
    align-items: center;
    justify-content: center;
    --tw-bg-opacity: 1;
    background-color: rgb(72 72 72 / var(--tw-bg-opacity));
    font-size: 1.25rem;
    line-height: 1.75rem;
    text-transform: uppercase;
    --tw-text-opacity: 1;
    color: rgb(255 255 255 / var(--tw-text-opacity));
}

.enquiry-grid #so-form-one input[type="submit"]:hover {
    --tw-text-opacity: 1;
    color: rgb(247 236 83 / var(--tw-text-opacity));
}

.enquiry-addr {
    margin-bottom: 2rem;
    width: 100%;
    --tw-bg-opacity: 1;
    background-color: rgb(247 236 83 / var(--tw-bg-opacity));
    padding: 2rem;
}

.enquiry-title {
    display: block;
    font-size: 24px;
}

.enquiry-subtitle {
    display: block;
    font-size: 28px;
    font-weight: 700;
}

.enquiry-addr a:hover {
    text-decoration: underline;
}

.faqs-acc li {
    position: relative;
    margin-bottom: 2rem;
}

.faqs-q {
    display: block;
    width: 100%;
    --tw-bg-opacity: 1;
    background-color: rgb(247 236 83 / var(--tw-bg-opacity));
    padding: 1rem;
    text-align: left;
    font-size: 1.25rem;
    line-height: 1.75rem;
    font-weight: 700;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 0.3s;
}

.faqs-q:focus {
    outline: 2px solid #0000;
    outline-offset: 2px;
}

.faqs-a {
    margin-top: 2rem;
    --tw-bg-opacity: 1;
    background-color: rgb(216 217 229 / var(--tw-bg-opacity));
    padding: 2rem;
    text-align: left;
    font-size: 1.125rem;
    line-height: 1.75rem;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

@media (min-width: 1024px) {
    .faqs-a {
        padding: 4rem 8rem;
    }
}

.faqs-icon {
    float: none;
    margin-left: 0.5rem;
    display: block;
    height: 1rem;
    width: 1rem;
    transform: translateY(-50%);
    position: absolute;
    top: 30px;
    right: 50px;
}

.feature_grid-inner {
    display: block;
    width: 100%;
    gap: 4rem;
}

@media (min-width: 1024px) {
    .feature_grid-inner {
        display: flex;
        gap: 6rem;
    }
}

@media (min-width: 1536px) {
    .feature_grid-inner {
        gap: 8rem;
    }
}

.feature_grid-content {
    width: 100%;
}

@media (max-width: 1024px) {
    .feature_grid-content {
        margin-bottom: 25px;
    }
}

@media (min-width: 640px) {
    .feature_grid-content {
        padding-bottom: 0;
    }
}

@media (min-width: 1024px) {
    .feature_grid-content {
        width: 50%;
    }
}

@media (min-width: 1536px) {
    .feature_grid-content {
        width: 33.333333%;
    }
}

@media (min-width: 1024px) {
    .feature_grid-banner .feature_grid-content {
        width: 50%;
    }
}

@media (min-width: 1536px) {
    .feature_grid-banner .feature_grid-content {
        width: 100%;
    }
}

.feature_grid-title {
    margin-bottom: 2rem;
    display: block;
    font-size: 35px;
    font-weight: 700;
    text-transform: capitalize;
    line-height: 3.2rem;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

@media (min-width: 1024px) {
    .feature_grid-title {
        margin-bottom: 4rem;
    }
}

.feature_grid-sub-title,
.feature_grid-tiles li h4 {
    margin-bottom: 1rem;
    display: block;
    font-size: 1.25rem;
    line-height: 1.75rem;
    font-weight: 700;
    text-transform: capitalize;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

.feature_grid-sub-title {
    margin-bottom: 0;
}

.feature_grid-tiles,
.feature_grid-tiles ul {
    float: none;
    display: block;
    width: 100%;
}

.feature_grid-tiles ul {
    gap: 2rem;
}

@media (min-width: 640px) {
    .feature_grid-tiles ul {
        display: flex;
    }
}

.feature_grid-tiles li {
    margin-bottom: 3rem;
    transition: 0.5s all;
}

/*.feature_grid-tiles li:hover {*/
/*    transform: translateY(-8px);*/
/*}*/

@media (min-width: 640px) {
    .feature_grid-tiles li {
        margin-bottom: 0;
        width: 0;
        flex: 1 1 0%;
    }
}

.feature_grid-tiles li a,
.feature_grid-tiles li a>div {
    float: none;
    display: block;
    width: 100%;
    position: relative;
    transition: 0.5s all;
}

.feature_grid-tiles li a>div:before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(247, 236, 83, 0.0);
    transition: 0.5s all;
}

.feature_grid-tiles li:hover a>div:before {
    background-color: rgba(247, 236, 83, 0.4);
}

.feature_grid-tiles li a>div {
    margin-bottom: 1rem;
    height: 200px;
}

#hero_two {
    position: relative;
    height: 100vh;
    max-height: 600px;
    width: 100%;
}

.hero_two-overlay {
    display: flex;
    height: 100%;
    width: 100%;
    align-items: center;
    justify-content: center;
    padding: 0;
}

@media (min-width: 768px) {
    .hero_two-overlay {
        align-items: flex-end;
        padding: 4rem;
    }
}

.hero_two-overlay {
    background: #00000080;
}

@media (min-width: 768px) {
    .hero_two-overlay .container {
        width: 100%;
    }
}

.hero_two-banner {
    height: 100%;
    width: 100%;
    border-width: 2rem;
    --tw-border-opacity: 1;
    border-color: rgb(247 236 83 / var(--tw-border-opacity));
}

.hero_two-content {
    height: 100%;
    width: 100%;
    --tw-bg-opacity: 1;
    background-color: rgb(247 236 83 / var(--tw-bg-opacity));
    padding-right: 2rem;
}

@media (min-width: 640px) {
    .hero_two-content {
        width: 70%;
    }
}

@media (min-width: 768px) {
    .hero_two-content {
        padding-right: 4rem;
    }
}

@media (min-width: 1536px) {
    .hero_two-content {
        width: 46%;
    }
}

@media (min-width: 1760px) {
    .hero_two-content {
        width: 46%;
    }
}

.hero_two-content-sub {
    width: 70%;
}

@media (min-width: 640px) {
    .hero_two-content-sub {
        width: 66%;
    }
}

@media (min-width: 1024px) {
    .hero_two-content-sub {
        width: 51%;
    }
}

#hero_two h1,
.hero-two-h1 {
    margin-bottom: 2rem;
    display: block;
    width: 100%;
    padding-top: 1rem;
    padding-bottom: 4rem;
    font-size: 2.25rem;
    line-height: 2.5rem;
    font-weight: 700;
    text-transform: capitalize;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

@media (min-width: 1024px) {

    #hero_two h1,
    .hero-two-h1 {
        font-size: 3rem;
        line-height: 1;
    }
}

@media (min-width: 1300px) {

    #hero_two h1,
    .hero-two-h1 {
        /*font-size: 3.75rem;*/
        font-size: 3rem;
        line-height: 1;
        line-height: 3.25rem;
    }
}

#hero_two h2,
.hero-two-h2 {
    display: block;
    border-bottom-width: 2px;
    --tw-border-opacity: 1;
    border-color: rgb(255 255 255 / var(--tw-border-opacity));
    padding-bottom: 1rem;
    font-size: 1.25rem;
    line-height: 1.75rem;
    font-weight: 700;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

.hero>div:first-child {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    overflow: hidden;
}

.hero {
    position: relative;
    height: 100vh;
    min-height: 600px;
    width: 100vw;
}

@media only screen and (min-width: 768px) and (max-width: 1024px) {
    html .hero {
        max-height: 58vh;
    }
}

.hero>div:nth-child(2) {
    position: absolute;
    top: 0;
    left: 0;
    display: flex;
    height: 100%;
    width: 100%;
    align-items: center;
    justify-content: center;
}

.hero video {
    position: absolute;
    top: 50%;
    left: 50%;
    min-height: 100%;
    min-width: 100%;
    --tw-translate-x: -50%;
    --tw-translate-y: -50%;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
    -o-object-fit: cover;
    object-fit: cover;
}

.hero>div:nth-child(2)>div {
    position: relative;
    display: flex;
    height: 6rem;
    width: 100%;
}

.hero>div:nth-child(2)>div span {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 100%;
    --tw-translate-x: -50%;
    --tw-translate-y: -50%;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
    padding-left: 2rem;
    padding-right: 2rem;
    text-align: center;
    font-size: 3.75rem;
    line-height: 1;
    font-weight: 600;
    --tw-text-opacity: 1;
    color: rgb(247 236 83 / var(--tw-text-opacity));
    opacity: 0;
    transition-property: opacity;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 1s;
    transition-timing-function: cubic-bezier(0.4, 0, 1, 1);
}

@media (min-width: 640px) {
    .hero>div:nth-child(2)>div span {
        font-size: 4.5rem;
        line-height: 1;
    }
}

@media (min-width: 1024px) {
    .hero>div:nth-child(2)>div span {
        font-size: 6rem;
        line-height: 1;
    }
}

@media (min-width: 1536px) {
    .hero>div:nth-child(2)>div span {
        font-size: 7.5rem;
    }
}

.hero>div:nth-child(2)>div span.active {
    opacity: 1;
}

.hero>div:nth-child(3) {
    position: absolute;
    bottom: 2rem;
    left: calc(50% - 12px);
    z-index: 10;
}

.hero>div:nth-child(3),
.hero>div:nth-child(3) svg {
    height: auto;
    width: 24px;
}

.hero>div:nth-child(3) svg path {
    fill: var(--yellow);
}

#latest-news {
    padding-top: 5rem;
    padding-bottom: 5rem;
}

#latest-news h3 {
    display: block;
    width: 100%;
    font-size: 3.75rem;
    line-height: 1;
    font-weight: 700;
    text-transform: capitalize;
    line-height: 4rem;
}

#latest-news h3,
#latest-news p {
    margin-bottom: 2rem;
    text-align: center;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

#latest-news p {
    font-size: 1.125rem;
    line-height: 1.75rem;
}

#latest-news ul {
    display: grid;
    width: 100%;
    list-style-type: none;
    grid-template-columns: repeat(1, minmax(0, 1fr));
    gap: 1rem;
}

@media (min-width: 768px) {
    #latest-news ul {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

#latest-news li {
    display: block;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    --tw-bg-opacity: 1;
    background-color: rgb(255 255 255 / var(--tw-bg-opacity));
    padding: 1rem;
    text-align: center;
}

#latest-news li a {
    position: relative;
    height: 100%;
    width: 100%;
    padding-bottom: calc(47px + 2rem);
}

#latest-news li img,
.latest-news-thumb {
    display: block;
    height: auto;
    width: 100%;
}

.latest-news-thumb {
    position: relative;
}

.latest-news-thumb:after {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 10;
    height: 100%;
    width: 100%;
    --tw-bg-opacity: 1;
    background-color: rgb(247 236 83 / var(--tw-bg-opacity));
    opacity: 0;
    transition-property: opacity;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 0.5s;
    content: "";
}

#latest-news li:hover .latest-news-thumb:after {
    opacity: 0.3;
}

#latest-news li h4 {
    position: relative;
    margin-bottom: 1rem;
    display: block;
    width: 100%;
    padding-top: 1rem;
    text-align: left;
    font-size: 24px;
    font-weight: 700;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
    transition-property: all;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 0.5s;
}

@media (min-width: 1024px) {
    #latest-news li h4 {
        font-size: 27px;
    }
}

@media (min-width: 1300px) {
    #latest-news li h4 {
        font-size: 30px;
    }
}

#latest-news li h4 {
    transform: translateY(0);
}

#latest-news li p {
    margin-bottom: 0;
    text-align: left;
}

@media (min-width: 768px) {
    #latest-news li p {
        display: none;
    }
}

@media (min-width: 1024px) {
    #latest-news li p {
        display: block;
    }
}

#latest-news li a span {
    border-radius: 2px;
    position: absolute;
    left: 0;
    bottom: 0;
    float: none;
    margin-top: 2rem;
    display: flex;
    height: 47px;
    width: 162px;
    align-items: center;
    justify-content: center;
    --tw-bg-opacity: 1;
    background-color: rgb(247 236 83 / var(--tw-bg-opacity));
    font-size: 1.25rem;
    line-height: 1.75rem;
    font-weight: 700;
    text-transform: uppercase;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

#latest-news li a span:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(72 72 72 / var(--tw-bg-opacity));
    --tw-text-opacity: 1;
    color: rgb(247 236 83 / var(--tw-text-opacity));
}

#more-articles {
    margin-top: 4rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

#more-articles span {
    margin-left: auto;
    margin-right: auto;
    border-bottom-width: 2px;
    --tw-border-opacity: 1;
    border-color: rgb(247 236 83 / var(--tw-border-opacity));
    padding-bottom: 0.5rem;
    font-size: 1.125rem;
    line-height: 1.75rem;
    font-weight: 700;
}

#more-articles:hover span {
    --tw-border-opacity: 1;
    border-color: rgb(72 72 72 / var(--tw-border-opacity));
    cursor: pointer;
}

.quotes {
    font-size: 1.125rem;
    line-height: 1.75rem;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

.quotes ul {
    display: grid;
    width: 100%;
    list-style-type: none;
    grid-template-columns: repeat(1, minmax(0, 1fr));
    gap: 40px;
}

@media (min-width: 768px) {
    .quotes ul {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

.quotes li {
    background: #e8e8e8;
    position: relative;
    padding: 4rem 2rem;
}

.quotes li svg {
    position: absolute;
    top: 0;
    left: 0;
    transform: translateX(2rem) translateY(-20px);
}

.quotes h2 {
    display: block;
    font-weight: 700;
    margin-bottom: 1rem;
    font-size: 22px;
    line-height: 30px;
}

.quotes p,
.quotes span:first-child {
    margin-bottom: 1rem;
}

#services {
    padding-top: 5rem;
    padding-bottom: 5rem;
}

#services h2 {
    margin-bottom: 4rem;
    display: block;
    width: 100%;
    text-align: center;
    font-size: 3.75rem;
    line-height: 1;
    font-weight: 700;
    text-transform: capitalize;
    line-height: 4rem;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

#services ul {
    display: grid;
    width: 100%;
    list-style-type: none;
    grid-template-columns: repeat(1, minmax(0, 1fr));
    gap: 3rem;
}

@media (min-width: 640px) {
    #services ul {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 1024px) {
    #services ul {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

@media (min-width: 1300px) {
    #services ul {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

#services li {
    width: 100%;
    text-align: center;
}

#services li img {
    position: relative;
    margin-bottom: 1rem;
    height: auto;
    width: 100%;
}

#services li .service-thumb {
    position: relative;
    transition-property: all;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 0.5s;
    transform: translateY(0);
}

#services li:hover .service-thumb {
    transform: translateY(-0.5rem);
}

#services li .service-thumb:after {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 10;
    height: 100%;
    width: 100%;
    --tw-bg-opacity: 1;
    background-color: rgb(247 236 83 / var(--tw-bg-opacity));
    opacity: 0;
    transition-property: opacity;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 0.5s;
    content: "";
}

#services li:hover .service-thumb:after {
    opacity: 0.3;
}

#services li hr {
    border-top-width: 1px;
    --tw-border-opacity: 1;
    border-color: rgb(247 236 83 / var(--tw-border-opacity));
}

#services li h3 {
    position: relative;
    margin-bottom: 1rem;
    display: block;
    width: 100%;
    padding-top: 1rem;
    text-align: left;
    font-size: 24px;
    font-weight: 700;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
    transition-property: all;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 0.5s;
}

@media (min-width: 1024px) {
    #services li h3 {
        font-size: 27px;
    }
}

@media (min-width: 1300px) {
    #services li h3 {
        font-size: 30px;
    }
}

#services li h3 {
    transform: translateY(0);
}

#services li:hover span {
    transform: translateY(0.5rem);
}

.spacer {
    float: none;
}

.spacer,
.staff ul {
    display: block;
    width: 100%;
}

@media (min-width: 1024px) {
    .staff ul {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 2rem;
    }
}

.staff li {
    margin-bottom: 2rem;
    display: block;
    width: 100%;
}

@media (min-width: 768px) {
    .staff li {
        display: flex;
    }
}

.staff li>div {
    width: 100%;
    padding: 1rem 1rem 0;
    position: relative;
}

.staff-container {
    position: sticky;
    top: 25px;
}

@media (min-width: 768px) {
    .staff li>div {
        width: 50%;
    }
}

.staff li>div {
    border-top: 2px solid var(--gray);
    border-right: 2px solid var(--gray);
}

.staff-l {
    text-align: center;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

.staff-thumb {
    margin-bottom: 1rem;
}

.staff-thumb img {
    margin-left: auto;
    margin-right: auto;
    height: auto;
    width: 66.666667%;
    border-radius: 100%;
    overflow: hidden;
}

.staff-title {
    margin-bottom: 0.5rem;
    display: block;
    width: 100%;
    --tw-bg-opacity: 1;
    background-color: rgb(247 236 83 / var(--tw-bg-opacity));
    padding: 0.5rem;
    font-size: 1.5rem;
    line-height: 2rem;
    font-weight: 700;
}

.staff-hons {
    font-size: 1rem;
    line-height: 1.5rem;
}

.staff-hons,
.staff-occ {
    margin-bottom: 2rem;
    display: block;
    width: 100%;
}

.staff-occ {
    font-size: 1.25rem;
    line-height: 1.75rem;
    font-weight: 700;
}

.staff-r>div {
    display: block;
    height: 100%;
    width: 100%;
    padding: 2rem;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
    background: #0000001a;
}

.staff-r>div p {
    margin-bottom: 1rem;
    display: block;
    font-size: 1rem;
    line-height: 1.5rem;
}

.stats li,
.stats ul {
    margin: 0;
    padding: 0;
    list-style-type: none;
}

.stats li,
.stats ul,
.stats-bar,
.stats-bar_colour,
.stats-bar_title {
    display: block;
    float: none;
    width: 100%;
}

.stats-bar {
    background: #e6e6e6;
    position: relative;
    margin: 0 0 1rem;
}

.stats-bar_colour {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    z-index: 1;
}

.stats-bar_title {
    position: relative;
    height: 55px;
    line-height: 55px;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    padding-left: 1rem;
    padding-right: 1rem;
    font-size: 22px;
    font-weight: 700;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

.stats-bar_title span {
    font-size: 36px;
    padding: 0 10px 0 0;
}

.winners ul {
    margin-bottom: 2rem;
    display: block;
    display: grid;
    width: 100%;
    grid-template-columns: repeat(1, minmax(0, 1fr));
    gap: 2rem;
}

@media (min-width: 640px) {
    .winners ul {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 768px) {
    .winners ul {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (min-width: 1300px) {
    .winners ul {
        gap: 4rem;
        padding-left: 4rem;
        padding-right: 4rem;
    }
}

@media (min-width: 1536px) {
    .winners ul {
        padding-left: 8rem;
        padding-right: 8rem;
    }
}

.winners li {
    display: block;
    width: 100%;
    --tw-bg-opacity: 1;
    background-color: rgb(247 236 83 / var(--tw-bg-opacity));
    padding: 1rem;
}

@media (min-width: 768px) {
    .winners li {
        display: flex;
    }
}

.winners li>div {
    position: relative;
    display: flex;
    height: 100%;
    width: 100%;
    --tw-bg-opacity: 1;
    background-color: rgb(255 255 255 / var(--tw-bg-opacity));
}

.winners li>span {
    display: block;
    width: 100%;
    --tw-bg-opacity: 1;
    background-color: rgb(247 236 83 / var(--tw-bg-opacity));
    padding: 0.5rem;
    font-size: 1.5rem;
    line-height: 2rem;
    font-weight: 700;
}

.winner-thumbnail {
    margin-top: 1rem;
    display: flex;
    width: 100%;
    align-items: center;
    justify-content: center;
}

.winner-thumbnail img {
    margin-left: auto;
    margin-right: auto;
    display: block;
    height: 160px;
    width: auto;
}

.winner-excerpt {
    float: none;
    display: block;
    width: 100%;
    padding: 1rem;
}

.winner-date {
    float: none;
    font-size: 1rem;
    line-height: 1.5rem;
    font-weight: 700;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

.winner-title {
    margin-top: 0.5rem;
    margin-bottom: 1rem;
    border-bottom-width: 1px;
    --tw-border-opacity: 1;
    border-color: rgb(247 236 83 / var(--tw-border-opacity));
    padding-bottom: 3rem;
    padding-top: 0.5rem;
    font-size: 1.25rem;
    line-height: 1.75rem;
    font-weight: 700;
}

.winner-title,
.winners li p {
    float: none;
    display: block;
    width: 100%;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

.winners li p {
    margin-bottom: 2rem;
    font-size: 1rem;
    line-height: 1.5rem;
}

.winner-button {
    position: absolute;
    bottom: 1rem;
    left: 1rem;
    height: 20px;
    font-size: 1rem;
    line-height: 1.5rem;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

#header {
    pointer-events: none;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 50;
    height: 100vh;
    width: 100%;
    background-color: initial;
}

@media (min-width: 1300px) {
    #header {
        height: auto;
    }
}

#header {
    background-color: #fff0;
    transition: background-color 0.3s ease;
    font-family: brandon-grotesque;
}

#header.nav-active {
    background-color: var(--yellow);
    position: fixed;
    left: 0;
    top: 0;
    height: 100vh;
    width: 100%;
}

.header__inner {
    pointer-events: none;
    display: block;
    height: 100%;
    width: 100%;
    padding: 1rem;
}

@media (min-width: 1300px) {
    .header__inner {
        display: flex;
        height: auto;
        align-items: center;
        justify-content: space-between;
    }
}

@media (min-width: 1536px) {
    .header__inner {
        padding: 1rem 0;
    }
}

#header .container {
    max-width: 1750px;
}

.header__logo {
    pointer-events: auto;
    float: none;
    display: block;
    width: 100%;
    transition-property: all;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 0.3s;
    transition-timing-function: cubic-bezier(0, 0, 0.2, 1);
}

@media (min-width: 1024px) {
    .header__logo {
        width: 200px;
    }
}

@media (min-width: 1300px) {
    .header__logo {
        float: none;
        width: 200px;
    }
}

@media (min-width: 1536px) {
    .header__logo {
        width: 328px;
    }
}

.header__logo svg {
    float: none;
    height: auto;
    width: 200px;
    transition-property: all;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 0.3s;
    transition-timing-function: cubic-bezier(0, 0, 0.2, 1);
}

@media (min-width: 1024px) {
    .header__logo svg {
        float: none;
    }
}

@media (min-width: 1300px) {
    .header__logo svg {
        height: 70px;
        width: auto;
    }
}

@media (min-width: 1536px) {
    .header__logo svg {
        height: 90px;
    }
}

.header__logo svg rect {
    fill: var(--yellow);
}

.header__logo svg path {
    fill: var(--black-light);
}

.header__menu {
    pointer-events: auto;
    display: none;
    /*height: calc(100vh - 150px - 2rem);*/
    width: 100%;
    align-items: center;
    overflow-y: scroll;
}

@media (min-width: 1300px) {
    .header__menu {
        display: flex;
        height: auto;
        width: auto;
        flex-grow: 1;
        justify-content: flex-end;
        overflow: visible;
    }
}

.nav-active .header__menu {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    flex-wrap: wrap;
}

@media (min-width: 1300px) {
    .nav-active .header__menu {
        justify-content: center;
    }
}

.header__nav {
    margin: 0;
    display: block;
    width: 100%;
    list-style-type: none;
    padding: 0;
    /*margin-bottom: 50px;*/
}

@media (min-width: 1300px) {
    .header__nav {
        display: flex;
        width: auto;
        justify-content: flex-end;
    }
}

.header__nav>li {
    position: relative;
    margin: 0 0.75rem 0 0;
}

.header__nav a {
    position: relative;
    display: block;
    padding: 1.5rem 18px;
    font-size: 1.25rem;
    line-height: 1.75rem;
    font-weight: 700;
    text-transform: uppercase;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
    text-decoration-line: none;
}

@media (min-width: 1024px) {
    .header__nav a {
        padding-top: 0.5rem;
        padding-bottom: 0.5rem;
    }
}

@media (min-width: 1300px) {
    .header__nav a {
        font-size: 1.125rem;
        line-height: 1.75rem;
        --tw-text-opacity: 1;
        color: rgb(247 236 83 / var(--tw-text-opacity));
    }
}

.header__nav>li>a:before {
    position: absolute;
    left: 0;
    top: 17px;
    display: none;
    height: 10px;
    width: 10px;
    --tw-bg-opacity: 1;
    background-color: rgb(247 236 83 / var(--tw-bg-opacity));
}

@media (min-width: 1300px) {
    .header__nav>li>a:before {
        display: block;
    }
}

.header__nav>li>a:before {
    border-radius: 2px;
    content: "";
    z-index: -1;
    transition: width 0.3s ease;
}

.header__nav>li>a:hover:before {
    width: 100%;
}

/*.header__nav > li:last-child {*/
/*    display: none;*/
/*}*/
.header__nav a:hover {
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

.header__nav .sub-menu {
    margin: 0;
    display: none;
    list-style-type: none;
    padding-left: 1.5rem;
    padding-right: 1.5rem;
}

@media (min-width: 1300px) {
    .header__nav .sub-menu {
        position: absolute;
        left: 0;
        width: auto;
        --tw-bg-opacity: 1;
        background-color: rgb(255 255 255 / var(--tw-bg-opacity));
        padding: 0;
    }
}

.header__nav .sub-menu li {
    position: relative;
    width: 100%;
    overflow: hidden;
}

.header__nav .sub-menu li:before {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 0;
    display: block;
    height: 100%;
    width: 100%;
    --tw-translate-x: 100%;
    --tw-bg-opacity: 1;
    background-color: rgb(247 236 83 / var(--tw-bg-opacity));
    transition: transform 0.3s ease;
}

.header__nav .sub-menu li:before,
.header__nav .sub-menu li:nth-child(2n):before {
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
    content: "";
}

.header__nav .sub-menu li:nth-child(2n):before {
    --tw-translate-x: -100%;
    transition: transform 0.3s ease-out;
}

.header__nav li:has(.sub-menu) {
    background: url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg" height="1em" viewBox="0 0 320 512"><!--! Font Awesome Free 6.4.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license (Commercial License) Copyright 2023 Fonticons, Inc.--><path d="M310.6 233.4c12.5 12.5 12.5 32.8 0 45.3l-192 192c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3L242.7 256 73.4 86.6c-12.5-12.5-12.5-32.8 0-45.3s32.8-12.5 45.3 0l192 192z"/></svg>');
    background-size: 10px auto;
    background-repeat: no-repeat;
    background-position: 100% 30px;
}

#header.nav-active .header__nav li:has(.sub-menu):hover {
    background: url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448.1 256" style="enable-background:new 0 0 448.1 256" xml:space="preserve"><path d="M201.5 246.7c12.5 12.5 32.8 12.5 45.3 0l192-192c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L224.1 178.8 54.7 9.5C42.2-3 21.9-3 9.4 9.5s-12.5 32.8 0 45.3l192 192 .1-.1z"/></svg>');
    background-size: 10px auto;
    background-repeat: no-repeat;
    background-position: 100% 40px;
}

.header__nav .sub-menu li:hover:before {
    --tw-translate-x: 0px;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.header__nav .sub-menu a {
    position: relative;
    padding: 0.5rem 30px;
    font-size: 1rem;
    line-height: 1.5rem;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

@media (min-width: 1300px) {
    .header__nav .sub-menu a {
        white-space: nowrap;
    }
}

.header__nav .sub-menu a:before {
    position: absolute;
    left: 0;
    top: 1rem;
    height: 7px;
    width: 14px;
    --tw-bg-opacity: 1;
    background-color: rgb(255 255 255 / var(--tw-bg-opacity));
}

@media (min-width: 1300px) {
    .header__nav .sub-menu a:before {
        display: none;
    }
}

.header__nav .sub-menu a:before {
    content: "";
    border-radius: 2px;
}

.header__nav>li:hover .sub-menu {
    display: block;
}

.header__end {
    pointer-events: auto;
    position: absolute;
    top: 0;
    right: 0;
    display: flex;
    width: auto;
    justify-content: flex-start;
    padding-top: 22px;
}

@media (min-width: 1300px) {
    .header__end {
        position: relative;
        top: auto;
        left: auto;
        width: 100%;
        width: auto;
        justify-content: flex-end;
        padding-top: 0;
    }
}

.header__end-inner {
    display: block;
    width: 100%;
    padding-left: 1rem;
    padding-right: 1rem;
}

@media (min-width: 1300px) {
    .header__end-inner {
        display: flex;
        width: auto;
        padding-left: 0;
        padding-right: 0;
        padding-bottom: 0;
    }
}

.header svg {
    height: 48px;
    width: auto;
    align-items: center;
    justify-content: center;
}

.header__tel {
    display: none;
    align-items: center;
}

@media (min-width: 1300px) {
    .header__tel {
        display: flex;
        padding-right: 1rem;
    }
}

.header__tel svg {
    display: block;
    height: 32px;
    width: auto;
}

.header__tel:hover {
    cursor: pointer;
}

.header__tel:hover .header__tel-border {
    fill: var(--yellow);
}

.header__tel svg path {
    fill: var(--yellow);
    transition: fill 0.3s ease;
}

.header__tel:hover svg path {
    fill: var(--gray);
}

.header__button {
    position: relative;
    float: none;
    margin-right: 1rem;
    display: none;
    height: 48px;
    width: auto;
    width: 140px;
    align-items: center;
    justify-content: center;
    background-color: initial;
    font-weight: 700;
    --tw-text-opacity: 1;
    color: rgb(247 236 83 / var(--tw-text-opacity));
    text-decoration-line: none;
    transition-property: all;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 0.3s;
}

.header__button:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(247 236 83 / var(--tw-bg-opacity));
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

@media (min-width: 1300px) {
    .header__button {
        float: none;
        margin-right: 1.5rem;
        display: flex;
    }
}

.header__button {
    border: 1px solid var(--yellow);
}

.header__mob-button {
    /*position: absolute;*/
    /*left: 2rem;*/
    /*bottom: 2rem;*/
    float: none;
    display: flex;
    height: 48px;
    width: 150px;
    align-items: center;
    justify-content: center;
    --tw-bg-opacity: 1;
    background-color: rgb(72 72 72 / var(--tw-bg-opacity));
    font-weight: 700;
    --tw-text-opacity: 1;
    color: rgb(247 236 83 / var(--tw-text-opacity));
    text-decoration-line: none;
    transition-property: all;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 0.3s;
    margin: 0 8px;
}

@media (min-width: 1300px) {
    .header__mob-button {
        float: none;
        display: none;
    }
}

.header__mob-tel {
    /*position: absolute;*/
    /*left: auto;*/
    /*right: 2rem;*/
}

.header__hamburger {
    float: none;
    margin-top: 0.5rem;
    margin-bottom: 0.5rem;
    display: block;
    cursor: pointer;
    overflow: visible;
    border-width: 0;
    background-color: initial;
    padding: 0;
    opacity: 0.7;
}

@media (min-width: 1300px) {
    .header__hamburger {
        display: none;
    }
}

.header__hamburger:hover,
.nav-active .header__hamburger {
    opacity: 1;
}

.header__hamburger-box {
    position: relative;
    display: inline-block;
    height: 1.5rem;
    width: 1.5rem;
}

.header__hamburger-inner {
    top: auto;
    bottom: 0;
    margin-top: -2px;
    display: block;
}

.header__hamburger-inner,
.header__hamburger-inner:after,
.header__hamburger-inner:before {
    position: absolute;
    height: 0.125rem;
    width: 1.5rem;
    border-radius: 0.25rem;
    --tw-bg-opacity: 1;
    background-color: rgb(247 236 83 / var(--tw-bg-opacity));
    transition-property: all;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 0.3s;
    transition-timing-function: cubic-bezier(0, 0, 0.2, 1);
}

.header__hamburger-inner:after,
.header__hamburger-inner:before {
    display: block;
    content: "";
}

.header__hamburger-inner:before {
    margin-top: -0.625rem;
}

.header__hamburger-inner:after {
    margin-top: -1.25rem;
}

.nav-active .header__hamburger-inner {
    --tw-translate-y: -0.625rem;
    --tw-rotate: -45deg;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
    --tw-bg-opacity: 1;
    background-color: rgb(0 0 0 / var(--tw-bg-opacity));
}

.nav-active .header__hamburger-inner:after {
    margin-top: 0;
    --tw-bg-opacity: 1;
    background-color: rgb(0 0 0 / var(--tw-bg-opacity));
    opacity: 0;
}

.nav-active .header__hamburger-inner:before {
    margin-top: 0;
    --tw-rotate: -90deg;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
    --tw-bg-opacity: 1;
    background-color: rgb(0 0 0 / var(--tw-bg-opacity));
}

@media only screen and (min-width: 1300px) {

    #header,
    #header.nav-active {
        background-color: #fff0;
    }

    .header__nav li:has(.sub-menu) {
        background: none;
    }
}

@media only screen and (min-width: 1680px) {
    .header__nav>li:last-child {
        display: block;
    }
}

#footer {
    float: none;
    display: block;
    width: 100%;
    --tw-bg-opacity: 1;
    background-color: rgb(72 72 72 / var(--tw-bg-opacity));
    padding-bottom: 2rem;
}

@media (min-width: 1300px) {
    #footer {
        padding-top: 4rem;
        padding-bottom: 4rem;
    }
}

@media only screen and (min-width: 768px) and (max-width: 1024px) {
    html .footer-grid {
        display: -ms-grid;
        display: grid;
        grid-template-columns: 1fr 1fr;
        grid-gap: 0rem 2.5rem;
    }

    .footer-grid>div:first-of-type {
        grid-column: 1 / span 2;
    }
}

.footer-grid {
    float: none;
    display: block;
    width: 100%;
    --tw-translate-y: 27px;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

@media (min-width: 1300px) {
    .footer-grid {
        display: flex;
        --tw-translate-y: 0;
        transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
        flex-direction: row;
        gap: 3rem;
    }
}

.footer-grid>div {
    position: relative;
    margin-bottom: 2rem;
}

@media (min-width: 1300px) {
    .footer-grid>div {
        margin-bottom: 0;
        width: calc(100% - 2rem);
        flex-grow: 1;
    }

    .footer-grid div:first-child {
        width: 400px;
    }
}

.footer-policy ul {
    display: block;
    width: 100%;
}

.footer-policy li {
    position: relative;
    display: inline-block;
    padding-right: 0.5rem;
}

.footer-policy li:first-child:before {
    content: "|";
    position: absolute;
    right: 0;
    color: var(--gray-light);
    transform: translateY(3px);
}

.footer-logo svg {
    height: auto;
    width: 100%;
    max-width: 200px;
}

@media (min-width: 1300px) {
    .footer-logo svg {
        max-width: 260px;
    }
}

.footer-logo svg rect {
    fill: var(--yellow);
}

.footer-logo svg path {
    fill: var(--black-light);
}

.footer-policy {
    display: none;
    width: 100%;
}

@media (min-width: 1300px) {
    .footer-policy {
        display: block;
    }
}

.footer-grid>div header span {
    margin-bottom: 1rem;
    display: block;
    border-bottom-width: 1px;
    --tw-border-opacity: 1;
    border-color: rgb(234 179 8 / var(--tw-border-opacity));
    padding-bottom: 0.5rem;
    font-size: 17px;
    font-weight: 700;
    --tw-text-opacity: 1;
    color: rgb(255 255 255 / var(--tw-text-opacity));
}

@media (min-width: 1300px) {
    .footer-grid>div header span {
        border-width: 0;
    }
}

@media (min-width: 1536px) {
    .footer-grid>div header span {
        font-size: 1.25rem;
        line-height: 1.75rem;
    }
}

.footer-grid>div li a,
.footer-grid>div li span,
.footer-grid>div p {
    display: block;
    font-size: 16px;
    line-height: 2;
    --tw-text-opacity: 1;
    color: rgb(216 217 229 / var(--tw-text-opacity));
}

@media (min-width: 1536px) {

    .footer-grid>div li a,
    .footer-grid>div li span,
    .footer-grid>div p {
        font-size: 17px;
    }
}

.footer-grid>div li a:hover {
    --tw-text-opacity: 1;
    color: rgb(247 236 83 / var(--tw-text-opacity));
}

.footer_col-5 svg {
    position: absolute;
    left: 0;
    margin-right: 6px;
    height: auto;
    width: 18px;
    transform: translateX(-30px) translateY(8px);
}

.footer_col-5 svg path {
    fill: var(--yellow);
    stroke: none;
    stroke-width: 0;
}

.footer-grid>div p>span {
    display: block;
}

@media (min-width: 1300px) {
    .footer-policy {
        position: absolute;
        bottom: 0;
        left: 0;
    }
}

.content-single {
    display: flex;
    width: 100%;
    flex-direction: column-reverse;
    align-items: flex-start;
    justify-content: space-between;
    gap: 4rem;
    padding: 4rem 1rem;
}

@media (min-width: 768px) {
    .content-single {
        flex-direction: row;
        padding-left: 2rem;
        padding-right: 2rem;
    }
}

@media (min-width: 1024px) {
    .content-single {
        padding-left: 4rem;
        padding-right: 4rem;
    }
}

@media (min-width: 1300px) {
    .content-single {
        padding-left: 8rem;
        padding-right: 8rem;
    }
}

.content-single-thumbnail {
    margin-bottom: 1rem;
    width: 100%;
}

@media (min-width: 768px) {
    .content-single-thumbnail {
        margin-bottom: 0;
        width: 50%;
    }
}

@media (min-width: 1300px) {
    .content-single-thumbnail {
        order: 1;
        width: 25%;
    }
}

.content-single-content {
    width: 100%;
    padding-right: 0;
}

@media (min-width: 768px) {
    .content-single-content {
        width: 50%;
        padding-right: 1rem;
    }
}

@media (min-width: 1300px) {
    .content-single-content {
        width: 75%;
    }
}

.content-single h1 {
    margin-bottom: 1rem;
    font-size: 1.875rem;
    line-height: 2.25rem;
    font-weight: 700;
}

@media (min-width: 1300px) {
    .content-single h1 {
        font-size: 2.25rem;
        line-height: 2.5rem;
    }
}

.content-single h2,
.content-single h3,
.content-single h4,
.content-single h5,
.content-single h6 {
    margin-top: 3rem;
    margin-bottom: 1rem;
    font-size: 1.5rem;
    line-height: 2rem;
    font-weight: 700;
}

@media (min-width: 1300px) {

    .content-single h2,
    .content-single h3,
    .content-single h4,
    .content-single h5,
    .content-single h6 {
        font-size: 1.875rem;
        line-height: 2.25rem;
    }
}

.content-single p {
    margin-bottom: 1rem;
    font-size: 1.125rem;
    line-height: 1.75rem;
}

.content-single ul {
    list-style: none;
    padding-left: 20px;
    margin-bottom: 2rem;
    list-style-type: none;
}

.content-single li {
    margin-bottom: 1rem;
    font-size: 1.125rem;
    line-height: 1.75rem;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

.content-single li:last-child {
    margin-bottom: 0;
}

.content-single li:before {
    content: "";
    width: 8px;
    height: 8px;
    line-height: 16px;
    margin-right: 10px;
    display: inline-block;
    border-radius: 9999px;
    --tw-bg-opacity: 1;
    background-color: rgb(247 236 83 / var(--tw-bg-opacity));
}

.content-single li a {
    text-decoration: underline;
}

.cat-nav {
    float: none;
    margin-bottom: 40px;
    display: block;
    width: 100%;
}

.cat-nav .container {
    display: flex;
}

.cat-nav_label {
    display: none;
    align-items: center;
    justify-content: center;
    --tw-bg-opacity: 1;
    background-color: rgb(216 217 229 / var(--tw-bg-opacity));
    padding-left: 6rem;
    padding-right: 6rem;
}

@media (min-width: 1024px) {
    .cat-nav_label {
        display: flex;
    }
}

.cat-nav_label span {
    font-size: 24px;
    font-weight: 700;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

.cat-nav ul {
    margin: 0;
    display: flex;
    list-style-type: none;
    flex-wrap: wrap;
    padding: 0;
    gap: 1rem 0;
}

.cat-nav li {
    margin-right: 1rem;
}

@media (min-width: 1024px) {
    .cat-nav li {
        margin-right: 0;
        margin-left: 1rem;
    }
}

.cat-nav li a {
    display: block;
    --tw-bg-opacity: 1;
    background-color: rgb(247 236 83 / var(--tw-bg-opacity));
    padding: 1rem;
    font-size: 1.125rem;
    line-height: 1.75rem;
    font-weight: 700;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

.cat-nav li:hover a {
    --tw-bg-opacity: 1;
    background-color: rgb(216 217 229 / var(--tw-bg-opacity));
}

.cat-list ul {
    margin-bottom: 2rem;
    display: block;
    display: grid;
    width: 100%;
    grid-template-columns: repeat(1, minmax(0, 1fr));
    gap: 2rem;
}

@media (min-width: 640px) {
    .cat-list ul {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 768px) {
    .cat-list ul {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (min-width: 1300px) {
    .cat-list ul {
        gap: 4rem;
        padding-left: 4rem;
        padding-right: 4rem;
    }
}

@media (min-width: 1536px) {
    .cat-list ul {
        padding-left: 8rem;
        padding-right: 8rem;
    }
}

.cat-list li {
    display: block;
    width: 100%;
    --tw-bg-opacity: 1;
    background-color: rgb(247 236 83 / var(--tw-bg-opacity));
    padding: 1rem;
}

@media (min-width: 768px) {
    .cat-list li {
        display: flex;
    }
}

.cat-list li a {
    position: relative;
    display: flex;
    height: 100%;
    width: 100%;
    --tw-bg-opacity: 1;
    background-color: rgb(255 255 255 / var(--tw-bg-opacity));
}

.cat-list li>span {
    display: block;
    width: 100%;
    --tw-bg-opacity: 1;
    background-color: rgb(247 236 83 / var(--tw-bg-opacity));
    padding: 0.5rem;
    font-size: 1.5rem;
    line-height: 2rem;
    font-weight: 700;
}

.cat-list_thumbnail {
    display: flex;
    width: 100%;
    align-items: center;
    justify-content: center;
}

.cat-list_thumbnail img {
    margin-left: auto;
    margin-right: auto;
    display: block;
    height: auto;
    width: 100%;
}

.cat-list_excerpt {
    float: none;
    display: block;
    width: 100%;
    padding: 1rem;
}

.cat-list_date {
    float: none;
    font-size: 1rem;
    line-height: 1.5rem;
    font-weight: 700;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

.cat-list_title {
    margin-top: 0.5rem;
    margin-bottom: 1rem;
    border-bottom-width: 1px;
    --tw-border-opacity: 1;
    border-color: rgb(247 236 83 / var(--tw-border-opacity));
    padding-bottom: 3rem;
    padding-top: 0.5rem;
    font-size: 1.25rem;
    line-height: 1.75rem;
    font-weight: 700;
}

.cat-list li p,
.cat-list_title {
    float: none;
    display: block;
    width: 100%;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

.cat-list li p {
    margin-bottom: 2rem;
    font-size: 1rem;
    line-height: 1.5rem;
}

.cat-list_button {
    position: absolute;
    bottom: 1rem;
    left: 1rem;
    height: 20px;
    font-size: 1rem;
    line-height: 1.5rem;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

.pagination {
    margin-top: 40px;
    margin-bottom: 40px;
}

.pagination .container ul {
    margin-left: auto;
    margin-right: auto;
    display: flex;
    max-width: 670px;
    align-items: center;
    justify-content: center;
    --tw-bg-opacity: 1;
    background-color: rgb(216 217 229 / var(--tw-bg-opacity));
    padding: 1rem;
}

.pagination .container li a,
.pagination .container li span {
    padding-left: 0.5rem;
    padding-right: 0.5rem;
    font-size: 1.125rem;
    line-height: 1.75rem;
    font-weight: 700;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

.pagination .container li .current,
.pagination .container li:hover a {
    text-decoration: underline;
}

#main .wp-block-columns {
    width: 100%;
    padding-right: 2rem;
    padding-left: 2rem;
}

@media (min-width: 640px) {
    #main .wp-block-columns {
        max-width: 640px;
    }
}

@media (min-width: 768px) {
    #main .wp-block-columns {
        max-width: 768px;
    }
}

@media (min-width: 901px) {
    #main .wp-block-columns {
        max-width: 901px;
    }
}

@media (min-width: 1024px) {
    #main .wp-block-columns {
        max-width: 1024px;
    }
}

@media (min-width: 1300px) {
    #main .wp-block-columns {
        max-width: 1300px;
    }
}

@media (min-width: 1536px) {
    #main .wp-block-columns {
        max-width: 1536px;
    }
}

@media (min-width: 1760px) {
    #main .wp-block-columns {
        max-width: 1760px;
    }
}

#main .wp-block-columns {
    float: none;
    display: block;
    max-width: 100%;
    padding: 0 2rem;
    margin-left: auto;
    margin-right: auto;
    width: 92%;
    max-width: 1640px;
}

@media (min-width: 1300px) {
    #main .wp-block-columns {
        width: 96%;
    }
}

@media (min-width: 768px) {
    .hero_two-overlay #main .wp-block-columns {
        width: 100%;
    }
}

#header #main .wp-block-columns {
    max-width: 1750px;
}

.cat-nav #main .wp-block-columns {
    display: flex;
}

.pagination #main .wp-block-columns ul {
    margin-left: auto;
    margin-right: auto;
    display: flex;
    max-width: 670px;
    align-items: center;
    justify-content: center;
    --tw-bg-opacity: 1;
    background-color: rgb(216 217 229 / var(--tw-bg-opacity));
    padding: 1rem;
}

.pagination #main .wp-block-columns li a,
.pagination #main .wp-block-columns li span {
    padding-left: 0.5rem;
    padding-right: 0.5rem;
    font-size: 1.125rem;
    line-height: 1.75rem;
    font-weight: 700;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

.pagination #main .wp-block-columns li .current,
.pagination #main .wp-block-columns li:hover a {
    text-decoration: underline;
}

@media (min-width: 1024px) {
    #main .wp-block-columns {
        float: none;
        display: flex;
        flex-wrap: nowrap;
        gap: 4rem;
        padding-left: 0;
        padding-right: 0;
    }
}

#main .wp-block-column {
    flex: 1 1 0%;
}

#main .wp-block-columns p {
    margin-bottom: 2rem;
    font-size: 1.125rem;
    line-height: 1.75rem;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
}

#main .wp-block-columns ul {
    list-style: none;
    padding-left: 20px;
    list-style-type: none;
}

#main .wp-block-columns li {
    margin-bottom: 1rem;
    font-size: 22px;
    font-weight: 700;
    --tw-text-opacity: 1;
    color: rgb(72 72 72 / var(--tw-text-opacity));
    display: -webkit-flex;
    display: flex;
    align-items: center;
}

#main .wp-block-columns li:last-child {
    margin-bottom: 0;
}

#main .wp-block-columns li:before {
    content: "";
    width: 20px;
    height: 20px;
    line-height: 20px;
    margin-right: 10px;
    display: inline-block;
    border-radius: 9999px;
    --tw-bg-opacity: 1;
    background-color: rgb(247 236 83 / var(--tw-bg-opacity));
}

.cont-form-col {
    position: relative;
}

.cont-form-col .wpcf7 {
    position: sticky;
    top: 75px;
}

.wpcf7 form .wpcf7-response-output {
    margin: 1em 0em;
    padding: 0.75rem 1rem;
    font-size: 17px;
}

.wpcf7 form.invalid .wpcf7-response-output {
    background-color: #ffb900;
}

.wpcf7-not-valid-tip {
    background-color: #dc3232;
    color: #fff;
    padding: 0.25rem 0.75rem;
}

.wpcf7 form.sent .wpcf7-response-output {
    background-color: #46b450;
    color: #fff;
}

@media only screen and (max-width: 767px) {
    html .hero_two-overlay {
        align-items: flex-end;
    }

    html .hero_two-overlay .container {
        margin-bottom: 50px;
    }

    .spacer {
        height: 25px !important;
    }

    .cont_img-content h2 {
        font-size: 28px;
    }

    .cont_img-content h3 {
        font-size: 25px;
    }

    .cont_img-content h4 {
        font-size;
        22px;
    }

    .cont_img-content h5,
    .cont_img-content h6 {
        font-size: 20px;
    }

    #main .wp-block-columns {
        padding: 0;
    }

    .banner-title {
        padding: 1rem 1.5rem;
    }

    #hero_two {
        max-height: fit-content;
    }

    .enquiry-subtitle {
        font-size: 22px;
    }

    #so-form-one input[type="email"],
    #so-form-one input[type="tel"],
    #so-form-one input[type="text"],
    #so-form-one textarea {
        -webkit-appearance: none;
    }

    #accreditations {
        padding-top: 2rem;
        padding-bottom: 2rem;
    }

    #accreditations li {
        padding-left: 0;
        padding-right: 0;
        margin-bottom: 2rem;
        width: 48%;
    }

    #accreditations li span {
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .hero_two-content-sub {
        width: 100%;
        padding-right: 0;
    }

    #hero_two h1,
    .hero-two-h1 {
        margin-bottom: 0rem;
        padding-bottom: 1.5rem;
        font-size: 2rem;
    }

    .feature_grid-content {
        margin-bottom: 2rem;
    }

    #footer div svg {
        position: relative;
        transform: none;
    }

    #footer .footer_col-5 li a {
        display: -webkit-flex;
        display: flex;
        align-items: center;
    }

    #awards ul {
        grid-template-columns: 1fr 1fr;
    }

    /* Mobile Font Size */
    .cont-form-title,
    #services h2,
    #latest-news h3,
    #awards h3 {
        font-size: 2.5rem;
        line-height: 3rem;
    }
}

input:focus {
    outline: 0;
}

html.nav-active .header__inner {
    /*position: fixed;*/
    overflow-y: scroll;
    padding-bottom: 50px;
}

/* Avoid Chrome to see Safari hack */
@supports (-webkit-touch-callout: none) {
    body {
        /* The hack for Safari */
        height: -webkit-fill-available;
    }
}

@media only screen and (max-width: 1440px) and (min-width: 1300px) {
    .header__nav a {
        font-size: 15px;
        padding: 0.5rem 1rem;
    }
}

.wp-block-heading {
    font-size: 32px;
    font-weight: 700;
    margin-top: 2rem;
    margin-bottom: 2rem;
}

.image-block picture img {
    display: block;
    margin: 0 auto;
}

.has-text-align-center {
    text-align: center;
}

@media screen and (max-width: 1024px) {
    .cont_double .cont_img-content>div {
        width: 100%;
    }
}

.documents-section {
    padding: 2rem;
}

.documents-title {
    font-size: 2.1875rem;
    margin-bottom: 0.5rem;
    color: #484848;
    font-weight: bold;
}

.documents-subtitle {
    font-size: 1.375rem;
    margin-bottom: 3rem;
    color: #484848;
    font-weight: normal;
}

.documents-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 3.75rem;
}

.document-item {
    text-align: center;
}

.document-item a {
    background-color: var(--yellow);
    display: block;
    padding: 3.5rem 0;
}

.document-icon {
    display: block;
    width: 60px;
    height: auto;
    margin: 0 auto 1rem;
}

.document-title {
    font-size: 1.25rem;
    margin: 0.5rem 0;
    color: #484848;
    font-weight: bold;
}

.document-description {
    color: #484848;
    font-size: 1.1875rem;
}

.document-title,
.document-description {
    text-align: left;
}

@media (max-width: 1024px) {
    .documents-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 768px) {
    .documents-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 480px) {
    .documents-grid {
        grid-template-columns: 1fr;
    }
}

.key-contacts-section {
    padding: 2rem;
    color: #484848;
}

.key-contacts-title {
    font-size: 2.1875rem;
    margin-bottom: 0.5rem;
    font-weight: bold;
}

.key-contacts-subtitle {
    font-size: 1.375rem;
    font-weight: normal;
    color: #484848;
    margin-bottom: 3.125rem;
}

.key-contacts-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
    position: relative;
}

.contact-card {
    position: relative;
    text-align: center;
    padding: 1rem 4rem;
    border-radius: 8px;
    background-color: #fff;
}

.contact-card::after {
    content: "";
    position: absolute;
    top: 0;
    right: -1rem;
    height: 100%;
    width: 1px;
    background-color: #484848;
}

.key-contacts-grid>.contact-card:nth-child(3n)::after {
    display: none;
}

@media (max-width: 992px) {
    .key-contacts-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .key-contacts-grid>.contact-card::after {
        right: -1rem;
    }

    .key-contacts-grid>.contact-card:nth-child(2n)::after {
        display: none;
    }

    .contact-card {
        padding: 1rem 1rem;
    }
}

@media (max-width: 600px) {
    .key-contacts-grid {
        grid-template-columns: 1fr;
    }

    .key-contacts-grid>.contact-card::after {
        display: none;
    }
}

.contact-image {
    width: 200px;
    height: 200px;
    object-fit: cover;
    border-radius: 50%;
    margin: 0 auto;
    margin-bottom: 1.875rem;
}

.contact-info {
    font-size: 0.95rem;
}

.contact-name {
    font-size: 1.25rem;
    font-weight: bold;
    margin-bottom: 1rem;
    padding: 0.5rem;
    background-color: var(--yellow);
}


.contact-accreditation {
    font-weight: normal;
}

.contact-role,
.contact-phone,
.contact-email {
    margin: 0.25rem 0;
    color: #484848;
    font-weight: normal;
    font-size: 1.375rem;
}

.contact-email a {
    color: inherit;
}

.contact-phone svg,
.contact-email svg {
    width: 16px;
    height: 16px;
    vertical-align: middle;
    fill: var(--yellow);
    position: relative;
    bottom: 0;
    display: inline-block;
    margin-right: 0.2rem;
}

.icon-phone,
.icon-email {
    display: inline-block;
}

.full-width-content-section {
    padding: 3rem 1rem;
    background-color: #f9f9f9;
    /* optional */
}

.container-full {
    max-width: 1200px;
    margin: 0 auto;
}

.full-width-content {
    font-size: 1.1875rem;
    line-height: 1.8;
    color: #484848;
    margin-bottom: 1.5rem;
}

.full-width-content h1,
.full-width-content h2,
.full-width-content h3 {
    margin-top: 1.5rem;
    font-size: 2.1875rem;
    margin-bottom: 1.25rem;
    color: #484848;
    font-weight: bold;
}

.full-width-content img {
    max-width: 100%;
    height: auto;
}

.full-width-content a {
    color: #0073aa;
    text-decoration: underline;
}

.full-width-content ul,
.full-width-content ol {
    margin-top: 1.5rem;
    padding-left: 1.5rem;
    margin-bottom: 1rem;
    list-style: disc;
}