/* -------------------------------------------------------------------------- */
/* RTB-MAIN.CSS (c) richardthebrave.com ------------------------------------- */

:root {

    --ratio: auto;

    --primary-bg:       #F7DBDC;
    --primary-light:    #EA9EA2;
    --primary-mid:      #CF333A;
    --primary:          #782429;
    --primary-dark:     #580E13;

    --secondary-bg:     #E7FCFF;
    --secondary-light:  #B5F6FF;
    --secondary-mid:    #76EEFF;
    --secondary:        #3299B6;
    --secondary-dark:   #006F83;

    --accent-bg:        #FFEFD4;
    --accent-light:     #FFD48A;
    --accent-mid:       #FCB877;
    --accent:           #F89B64;
    --accent-dark:      #D57B45;

    --neutral-bg:       #F2F5F8;
    --neutral-light:    #CCD5E1;
    --neutral-mid:      #94A3B7;
    --neutral:          #65748B;
    --neutral-dark:     #3F4A5A;

    --white: #fff;
    --black: #000;

    /* 360px -> 1440px */
    --space-1:      clamp(0.375rem, 0.3333rem + 0.1852vw, 0.5rem);  /*  6->8px  */
    --space-2:      clamp(0.5625rem, 0.5rem + 0.2778vw, 0.75rem);   /*  9->12px */
    --space-3:      clamp(0.75rem, 0.6667rem + 0.3704vw, 1rem);     /* 12->16px */
    --space-4:      clamp(1rem, 0.9167rem + 0.3704vw, 1.25rem);     /* 16->20px */
    --space-5:      clamp(1.3125rem, 1.25rem + 0.2778vw, 1.5rem);   /* 21->24px */
    --space-6:      clamp(1.6875rem, 1.5833rem + 0.463vw, 2rem);    /* 27->32px */
    --space-7:      clamp(2.0625rem, 1.75rem + 1.3889vw, 3rem);     /* 33->48px */
    --space-8:      clamp(2.8125rem, 2.4167rem + 1.7593vw, 4rem);   /* 45->64px */
    --space-9:      clamp(3.375rem, 2.8333rem + 2.4074vw, 5rem);    /* 54->80px */
    --space-10:     clamp(3.9375rem, 3.25rem + 3.0556vw, 6rem);     /* 63->96px */

    /* @link https://utopia.fyi/clamp/calculator?a=360,1440,11—13|13—16|15—18|17—20|21—25|27—40|36—55|44—80&p=foo */
    /* 360px -> 1440px */

    --text-xxs: clamp(0.6875rem, 0.6458rem + 0.1852vw, 0.8125rem);  /* 11->13px  footer stuff */
    --text-xs: clamp(0.8125rem, 0.75rem + 0.2778vw, 1rem);          /* 13->16px  h6 */
    --text-sm: clamp(0.9375rem, 0.875rem + 0.2778vw, 1.125rem);     /* 15->18px  h5 */
    --text-base: clamp(1.0625rem, 1rem + 0.2778vw, 1.25rem);        /* 17->20px  body copy, h4 */
    --text-md: clamp(1.3125rem, 1.2292rem + 0.3704vw, 1.5625rem);   /* 21->25px  h3, ledes */
    --text-lg: clamp(1.6875rem, 1.4167rem + 1.2037vw, 2.5rem);      /* 27->40px  h2 */
    --text-xl: clamp(2.25rem, 1.8542rem + 1.7593vw, 3.4375rem);     /* 36->55px  h1 */
    --text-xxl: clamp(2.75rem, 2rem + 3.3333vw, 5rem);              /* 44->80px  not currently in use */

    --radius-xs: var(--space-1);
    --radius-sm: var(--space-2);
    --radius-base: var(--space-3);
    --radius-md: var(--space-4);
    --radius-lg: var(--space-5);
    --radius-xl: var(--space-6);


}

/* -------------------------------------------------------------------------- */
/* MARK: Reset
*/

*, *::before, *::after            { box-sizing: border-box; }
*                                 { margin: 0; }
html                              { font-size: 100%; scrollbar-gutter: stable; }
body                              { background-color: var(--primary-XXX); color: var(--neutral-dark); font-family: 'font-primary', system-ui, sans-serif; font-size: var(--text-base); font-style: normal; font-weight: 400; line-height: 1.6; -webkit-font-smoothing: antialiased; }
img, picture, video, canvas, svg  { aspect-ratio: var(--ratio); display: block; height: auto; max-width: 100%; }
input, button, textarea, select   { font: inherit; }
p, h1, h2, h3, h4, h5, h6         { overflow-wrap: break-word; }
hr                                { background-color: black; border: 0; box-sizing: content-box; height: 1px; margin: 0; overflow: visible; }
#root, #__next                    { isolation: isolate; }
strong                            { font-weight: 700; }
em                                { font-style: italic; }
:focus:not(:focus-visible)        { outline: none; box-shadow: none; }
:focus-visible                    { outline: none; box-shadow: 0 0 0 6px var(--neutral-light); }

/* Smooth scrolling IF user doesn't have a preference due to motion sensitivities */
/* https://moderncss.dev/pure-css-smooth-scroll-back-to-top/ */
@media screen and (prefers-reduced-motion: no-preference) {
    html {
        scroll-behavior: smooth;
    }
}

.pulsate-fwd{-webkit-animation:pulsate-fwd .5s ease-in-out infinite both;animation:pulsate-fwd .5s ease-in-out infinite both}

/* ----------------------------------------------
 * Generated by Animista on 2025-1-19 15:14:52
 * Licensed under FreeBSD License.
 * See http://animista.net/license for more info. 
 * w: http://animista.net, t: @cssanimista
 * ---------------------------------------------- */

 @-webkit-keyframes pulsate-fwd{0%{-webkit-transform:scale(1);transform:scale(1)}50%{-webkit-transform:scale(1.05);transform:scale(1.05)}100%{-webkit-transform:scale(1);transform:scale(1)}}@keyframes pulsate-fwd{0%{-webkit-transform:scale(1);transform:scale(1)}50%{-webkit-transform:scale(1.05);transform:scale(1.05)}100%{-webkit-transform:scale(1);transform:scale(1)}}

/* -------------------------------------------------------------------------- */
/* MARK: Fonts
*/

/* Supreme Var */
@font-face {
    font-family: 'font-primary';
    src:    url('/assets/fonts/supreme-var/supreme-var.woff2') format('woff2-variations'),
            url('/assets/fonts/supreme-var/supreme-var.ttf') format('truetype-variations');
    font-weight: 100 800;
    font-display: swap;
        
}
.font-primary { font-family: 'font-primary', sans-serif; font-style: normal; }
.font-primary-100 { font-family: 'font-primary', sans-serif; font-style: normal; font-weight: 100; }
.font-primary-200 { font-family: 'font-primary', sans-serif; font-style: normal; font-weight: 200; }
.font-primary-300 { font-family: 'font-primary', sans-serif; font-style: normal; font-weight: 300; }
.font-primary-400 { font-family: 'font-primary', sans-serif; font-style: normal; font-weight: 400; }
.font-primary-500 { font-family: 'font-primary', sans-serif; font-style: normal; font-weight: 500; }
.font-primary-600 { font-family: 'font-primary', sans-serif; font-style: normal; font-weight: 600; }
.font-primary-700 { font-family: 'font-primary', sans-serif; font-style: normal; font-weight: 700; }
.font-primary-800 { font-family: 'font-primary', sans-serif; font-style: normal; font-weight: 800; }

/* Supreme Var Italic */
@font-face {
    font-family: 'font-primary';
    src:    url('/assets/fonts/supreme-var/supreme-var-italic.woff2') format('woff2-variations'),
            url('/assets/fonts/supreme-var/supreme-var-italic.ttf') format('truetype-variations');
    font-weight: 100 800;
    font-display: swap;
    font-style: italic; 
}
.font-primary-i { font-family: 'font-primary', sans-serif; font-style: italic; }
.font-primary-100i { font-family: 'font-primary', sans-serif; font-style: italic; font-weight: 100; font-style: italic; }
.font-primary-200i { font-family: 'font-primary', sans-serif; font-style: italic; font-weight: 200; font-style: italic; }
.font-primary-300i { font-family: 'font-primary', sans-serif; font-style: italic; font-weight: 300; font-style: italic; }
.font-primary-400i { font-family: 'font-primary', sans-serif; font-style: italic; font-weight: 400; font-style: italic; }
.font-primary-500i { font-family: 'font-primary', sans-serif; font-style: italic; font-weight: 500; font-style: italic; }
.font-primary-600i { font-family: 'font-primary', sans-serif; font-style: italic; font-weight: 600; font-style: italic; }
.font-primary-700i { font-family: 'font-primary', sans-serif; font-style: italic; font-weight: 700; font-style: italic; }
.font-primary-800i { font-family: 'font-primary', sans-serif; font-style: italic; font-weight: 800; font-style: italic; }


/* -------------------------------------------------------------------------- */
/* MARK: Colours
*/

.bg-neutral-bg      { background-color: var(--neutral-bg); }
.bg-neutral-light   { background-color: var(--neutral-light); }
.bg-neutral-mid     { background-color: var(--neutral-mid); }
.bg-neutral         { background-color: var(--neutral); }
.bg-neutral-dark    { background-color: var(--neutral-dark); }
.bg-primary-bg      { background-color: var(--primary-bg); }
.bg-primary-light   { background-color: var(--primary-light); }
.bg-primary-mid     { background-color: var(--primary-mid); }
.bg-primary         { background-color: var(--primary); }
.bg-primary-dark    { background-color: var(--primary-dark); }
.bg-secondary-bg    { background-color: var(--secondary-bg); }
.bg-secondary-light { background-color: var(--secondary-light); }
.bg-secondary-mid   { background-color: var(--secondary-mid); }
.bg-secondary       { background-color: var(--secondary); }
.bg-secondary-dark  { background-color: var(--secondary-dark); }
.bg-accent-bg       { background-color: var(--accent-bg); }
.bg-accent-light    { background-color: var(--accent-light); }
.bg-accent-mid      { background-color: var(--accent-mid); }
.bg-accent          { background-color: var(--accent); }
.bg-accent-dark     { background-color: var(--accent-dark); }
.bg-white           { background-color: var(--white); }
.bg-black           { background-color: var(--black); }

.neutral-bg         { color: var(--neutral-bg); }
.neutral-light      { color: var(--neutral-light); }
.neutral-mid        { color: var(--neutral-mid); }
.neutral            { color: var(--neutral); }
.neutral-dark       { color: var(--neutral-dark); }
.primary-bg         { color: var(--primary-bg); }
.primary-light      { color: var(--primary-light); }
.primary-mid        { color: var(--primary-mid); }
.primary            { color: var(--primary); }
.primary-dark       { color: var(--primary-dark); }
.secondary-bg       { color: var(--secondary-bg); }
.secondary-light    { color: var(--secondary-light); }
.secondary-mid      { color: var(--secondary-mid); }
.secondary          { color: var(--secondary); }
.secondary-dark     { color: var(--secondary-dark); }
.accent-bg          { color: var(--accent-bg); }
.accent-light       { color: var(--accent-light); }
.accent-mid         { color: var(--accent-mid); }
.accent             { color: var(--accent); }
.accent-dark        { color: var(--accent-dark); }
.white              { color: var(--white); }
.black              { color: var(--black); }


.object-top-left{object-position:top left;}.object-top-center{object-position:top center;}.object-top-right{object-position:top right;}.object-center-left{object-position:center left;}.object-center{object-position:center center;}.object-center-right{object-position:center right;}.object-bottom-left{object-position:bottom left;}.object-bottom-center{object-position:bottom center;}.object-bottom-right{object-position:bottom right;}


/* -------------------------------------------------------------------------- */
/* MARK: Typography
*/

h1, h2, h3, h4, h5, h6, p, ul, ol {
  margin-bottom: var(--space-4);
}

h1, h2, h3, h4, h5, h6 {
    font-weight: 750;
    letter-spacing: -1px;
    line-height: 1.1;
}

.text-xxl       { font-size: var(--text-xxl); }
.text-xl, h1    { font-size: var(--text-xl); }
.text-lg, h2    { font-size: var(--text-lg); }
.text-md, h3    { font-size: var(--text-md); }
.text-base, h4  { font-size: var(--text-base); }
.text-sm, h5    { font-size: var(--text-sm); }
.text-xs, h6    { font-size: var(--text-xs); }

.list-none { list-style: none; }

.text-center { text-align: center; }
.text-left { text-align: left; }
.text-right { text-align: right; }

/* -------------------------------------------------------------------------- */
/* MARK: Links
*/

a           { color: var(--primary); text-decoration-color: var(--neutral-light); text-underline-offset: 0.2em; text-decoration-thickness: 0.05em; }
a:hover     { color: var(--primary); }
a:active    { color: var(--accent-dark); }

.white-links a       { color: var(--white); }
.white-links a:hover { color: var(--accent); }


.arrow-wrap {
    line-height: 1;
}

.arrow-right {
    border: 1px solid var(--neutral-light);
    display: inline-block;
    height: var(--space-6);
    width: var(--space-6);
    padding: 2px;
}


/* -------------------------------------------------------------------------- */
/* MARK: Buttons
*/

.btn    {
    background-color: var(--primary);
    border: 1px solid transparent;
    border-radius: var(--radius-xl);
    color: var(--white);
    cursor: pointer;
    display: inline-block;
    font-size: inherit;
    font-weight: 600;
    line-height: 1.2;
    padding: var(--space-2) var(--space-4);
    text-decoration: none;
}

.btn:hover { background-color: var(--primary-mid); color: var(--white); }

.btn--light { background-color: var(--primary-light); color: var(--neutral-dark) }
.btn--light:hover { background-color: var(--primary-mid); }

.btn--primary { background-color: var(--primary); }
.btn--primary:hover { background-color: var(--primary-dark); }
.btn--primary.btn--light { background-color: var(--primary-light); }
.btn--primary.btn--light:hover { background-color: var(--primary-mid); }

.btn--secondary { background-color: var(--secondary); }
.btn--secondary:hover { background-color: var(--secondary-dark); }
.btn--secondary.btn--light { background-color: var(--secondary-light); }
.btn--secondary.btn--light:hover { background-color: var(--secondary-mid); }

.btn--accent { background-color: var(--accent); }
.btn--accent:hover { background-color: var(--accent-dark); }
.btn--accent.btn--light { background-color: var(--accent-light); }
.btn--accent.btn--light:hover { background-color: var(--accent-mid); }

.btn--neutral { background-color: var(--neutral); }
.btn--neutral:hover { background-color: var(--neutral-dark); }
.btn--neutral.btn--light { background-color: var(--neutral-light); }
.btn--neutral.btn--light:hover { background-color: var(--neutral-mid); }

.btn--small { font-size: var(--text-sm); padding: var(--space-1) var(--space-3); }
.btn--block { display: block; text-align: center; }

.btn--outline { background-color: transparent; color: var(--primary); border-color: currentColor; }
.btn--outline:hover { background-color: transparent; border-color: currentColor; color:  var(--primary-dark); }



/* -------------------------------------------------------------------------- */
/* MARK: Content & Layout Grid
*/

main {
    padding: var(--space-8) 0;
    row-gap: var(--space-8);
}

.content-grid {
    --padding-inline: var(--space-4);
    --padding-doubled: calc(2 * var(--padding-inline));
    --content-max-width: 83.75rem; /* 1340px */
    --breakout-max-width: calc(100% - var(--padding-doubled));  /* 1800px */
    --breakout-size: calc(
        (var(--breakout-max-width) - var(--content-max-width)) / 2
    );

    display: grid;
    grid-template-columns:
        [full-width-start] minmax(var(--padding-inline), 1fr)
            [breakout-start] minmax(0, var(--breakout-size))
            [content-start] min(
                100% - (var(--padding-inline) * 2),
                var(--content-max-width)
            )
            [content-end]
            minmax(0, var(--breakout-size)) [breakout-end]
            minmax(var(--padding-inline), 1fr) [full-width-end];
}

.content-grid > * {
    margin-bottom: 0;
}

.content-grid> :not(.breakout, .full-width),
.full-width> :not(.breakout, .full-width) {
    grid-column: content;
}

.content-grid>.breakout {
    grid-column: breakout;
    display: grid;
    grid-template-columns: inherit;
}
.content-grid>.breakout>* {
    grid-column: content;
}

.content-grid>.full-width {
    grid-column: full-width;
    display: grid;
    grid-template-columns: inherit;
}

img.full-width {
    width: 100%;
    max-height: 45vh;
    object-fit: cover;
}

.w-100 {
    width: 100%;
}

/* -------------------------------------------------------------------------- */
/* MARK: Display
*/

.block 			{ display: block; }
.none 			{ display: none; }
.inline-block 	{ display: inline-block; }
.overflow-hide  { overflow: hidden; }
.pos-rel        { position: relative; }

/* -------------------------------------------------------------------------- */
/* MARK: Courtesy Nav
*/

.courtesy {
    padding: var(--space-1) 0;
}
.courtesy-nav ul {
    display: flex;
    justify-content: center;
    gap: var(--space-6);
    list-style: none;
    margin: 0;
    padding: 0;
}

.courtesy-nav a {
    color: var(--neutral);
    text-decoration: none;
}

/* -------------------------------------------------------------------------- */
/* MARK: Header
*/

.logo {
    display: flex;
    gap: var(--space-2);
    margin-left: -0.5rem;
    position: relative;
    z-index: 2;
}

.logo-nav-wrap {
    align-items: center;
    display: flex;
    gap: var(--space-4);
    padding: var(--space-4) 0;
    justify-content: space-between;
}

.mobile-nav__btn {
    background-color: transparent;
    color: var(--neutral-dark);
    padding: 0;
}

.mobile-nav__btn:hover {
    background-color: transparent;
    color: var(--neutral-dark);
}

.mobile-nav__label {
    padding-right: 3px;
}

/* -------------------------------------------------------------------------- */
/* MARK: Hero
*/

.page-title-hero {
    background: radial-gradient(circle farthest-side at center bottom, rgba(40,46,56,1) 0%, rgba(40,46,56,1) 45%, rgba(48,56,67,1) 45%, rgba(48,56,67,1) 65%, rgba(55,65,78,1) 65%, rgba(55,65,78,1) 95%, rgba(63,74,89,1) 95%); 
    color: white;
    text-align: center;
}

.page-title-hero-copy {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.page-title-hero-copy > * {
    margin-block: 0;
}

.page-title-hero-deck {
    margin-inline: auto;
    max-width: 40rem;
}

.page-title-hero-deck a {
    color:  white;
}

.page-title-hero-btn-wrap {
    display: flex;
    flex-wrap: wrap; align-items: center;
    gap: var(--space-2);
    justify-content: center;
}

.page-title-hero-inner {
    padding-top: calc(2 * var(--space-8));
}

.page-title-hero-img-wrap {
    position: relative;
    max-width: 45rem;
    margin-inline: auto;
}
.page-title-hero-img {
    transform: scaleX(-1);
    margin-bottom: calc(-1 * var(--space-6));
    margin-top: var(--space-6);
    max-width: 15rem;
    margin-inline: auto;
    position: relative;
    z-index: 2;
}
.page-title-hero-icon {
    position: absolute;
    filter: saturate(0) contrast(0.8);
    width: calc(2 * var(--space-8));
    mix-blend-mode: overlay;
}
.page-title-hero-icon img {
    transition: all 0.5s ease-in-out;

}

/* combi boiler */
.page-title-hero-img-wrap :nth-child(2){
    left: 0%;
    top: 5%;
    transform: rotate(4deg);
}
/* busted pipe */
.page-title-hero-img-wrap :nth-child(3){
    right: 2%;
    top: 5%;
    max-width: 6rem;
    transform: rotate(-14deg);
}
/* kitchen */
.page-title-hero-img-wrap :nth-child(4){
    right: 5%;
    bottom: 20%;
    transform: rotate(10deg);
}
/* tub */
.page-title-hero-img-wrap :nth-child(5){
    left: 4%;
    bottom: 20%;
    max-width: 6rem;
    transform: rotate(-14deg);
}

/* -------------------------------------------------------------------------- */
/* MARK: Page Title
*/

.page-title {
    color: white;
    margin-bottom: var(--space-4);
    overflow: hidden;
    position: relative;
}



.page-title::after {
    content: '';
    background-color: var(--neutral-dark);
    background: radial-gradient(circle farthest-side at left center, rgba(40,46,56,1) 0%, rgba(40,46,56,1) 45%, rgba(48,56,67,1) 45%, rgba(48,56,67,1) 60%, rgba(55,65,78,1) 60%, rgba(55,65,78,1) 80%, rgba(63,74,89,1) 80%); 
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    z-index: 0;
    height: 100%;
    width: 100%;
}

.page-title a {
    color: inherit;
}

.page-title-inner {
    align-items: end;
    display: grid;
    column-gap: var(--space-8);
}

.page-title-btn-wrap {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2) var(--space-4);
    align-items: center;
    padding-top: var(--space-4);
}

.page-title-btn {
    position: relative;
    padding-right: var(--space-8);
    background-color: var(--neutral);
    transition: background-color 0.3s ease-in-out;
}

.page-title-btn:hover {
    background-color: var(--secondary);
}

.page-title-btn::after {
    content: '→';
    display: block;
    position: absolute;
    right: 0; top: 0; bottom: 0;
    background-color: var(--secondary);
    aspect-ratio: 1;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background-color 0.6s ease-in-out;
}

.page-title-btn:hover::after {
    background-color: var(--secondary-mid);
}

.page-title-provides {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-1) var(--space-4);
    margin: 0 0 var(--space-4) 0;
    padding: 0;
    font-weight: 600;
    font-size: var(--text-sm);
    color: var(--neutral-light);
}


.provides-item {
    /* background-color: rgba(0, 0, 0, 0.1); */
    /* padding: var(--space-1) var(--space-2); */
    border-radius: var(--radius-xs);
    display: flex;
    align-items: center;
    flex-wrap: nowrap;
    gap: var(--space-1);
}
.provides-svg {
    width: 1.5rem;
    display: block;
    color: inherit;
}

.page-title-img {
    --page-title-padding: var(--space-4);
    --negative-margin: calc( var(--page-title-padding) * -1 );
    aspect-ratio: 3/2;
    height: 100%;
    margin-left: var(--negative-margin);
    margin-right: var(--negative-margin);
    position: relative;
    z-index: 2;
}

.page-title-img > picture {
    position: absolute;
    left: 0; right: 0; top: 0; bottom: 0;
}

.page-title-img > picture > img {
    height: 100%;
    width: 100%;
    object-fit: cover;
}
.page-title-copy {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    padding-top: calc( var(--space-8) * 2 );
    padding-bottom: var(--space-8);
}
.page-title-copy > * {
    margin-block: 0;
}

.page-title-deck {
}

.page-title-pill:hover {
}

/* -------------------------------------------------------------------------- */
/* MARK: Blocks Wrapper
*/

.blocks {
    display: flex;
    flex-direction: column;
    gap: var(--space-8);
}

/* -------------------------------------------------------------------------- */
/* MARK: Intro Block for Service Pages
*/

.intro-with-nav {
    align-items: start;
    display: grid;
    gap: var(--space-8) var(--space-4);
}

.intro-main p:first-of-type {
    border-left: 2px solid var(--neutral-light);
    padding-left: var(--space-5);
}
.intro-main p:first-of-type::after {
    display: block;
    content: '';
    border-bottom: 2px solid var(--neutral-light);
    padding-bottom: var(--space-5);
    width: 20%;
    margin-left: calc(-1 * var(--space-5));
    margin-bottom: 0;
}

.intro-main {
    grid-column: 1 / 9;
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}
.intro-main > * {
    margin-block: 0;
}

.intro-sidebar {
    border: 1px solid var(--neutral-light);
    padding: var(--space-2);
    grid-column: 9 / -1;
}

.sidebar-nav-ul {
    list-style: none;
    margin: 0;
    padding: 0;
}
.sidebar-nav-link {
    color: var(--neutral);
    display: block;
    padding: var(--space-1);
    text-decoration: none;
}
.sidebar-nav-title {
    text-transform: uppercase;
    letter-spacing: 1px;
    font-weight: 550;
    margin: 0;
} .sidebar-nav-title .sidebar-nav-link {
    padding-block: var(--space-2);
}
.sidebar-nav-link:hover {
    background-color: var(--neutral-light);
    color: var(--neutral-dark);
}
.sidebar-nav-link.active {
    background-color: var(--neutral-bg);
    color: var(--neutral-dark);
}

/* -------------------------------------------------------------------------- */
/* MARK: Block Header Block
*/

.block-header {
    margin-bottom: var(--space-6);
}

.block-header-title::before {
    display: block;
    content: '';
    background-color: var(--primary-mid);
    height: var(--space-1);
    width: 100%;
    max-width: var(--space-8);
    margin-bottom: var(--space-4);
}

.block-header-text {
    max-width: 60ch;
}


/* -------------------------------------------------------------------------- */
/* MARK: Portal Nav Block
*/

.portal-ul {
    display: grid;
    gap: var(--space-4);
    list-style: none;
    margin: 0;
    padding: 0;
}

.portal-li-link {
    border: 1px solid var(--neutral-light);
    color: var(--neutral-dark);
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    height: 100%;
    padding: var(--space-4);
    text-decoration: none;
}

.portal-li-link:hover {
    border-color: var(--neutral);
}

.portal-li-link:hover .arrow-right {
    border-color: var(--primary);
    background-color: var(--primary);
    color: white;
}

.portal-li-link > * {
    margin: 0;
}

.portal-li-icon {
    width: var(--space-9);
    height: var(--space-9);
    margin-bottom: var(--space-1);
}

.portal-li-title {
    text-wrap: balance;
}

.portal-arrow {
    margin-top: auto;
    padding-top: var(--space-4);
}




/* -------------------------------------------------------------------------- */
/* MARK: Two-Column Block
*/

.two-column {
    display: grid;
    gap: var(--space-4);
}

.two-column-item {
    background-color: var(--neutral-bg);
    display: grid;
}

.two-column-text {
    padding: var(--space-4);
    align-self: center;
}

.two-column-image img {
    object-fit: cover;
    width: 100%;
    height: 100%;
}


/* -------------------------------------------------------------------------- */
/* MARK: Contact Page
*/

.contact-cards {
    display: grid;
    gap: var(--space-4);
}

.contact-cards > ul {
    list-style: none;
    margin: 0;
}

.contact-card {
    background-color: var(--neutral-bg);
    border: 1px solid var(--neutral-light);
    padding: var(--space-6) var(--space-4);
}

.contact-social {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-1);
    margin-top: var(--space-1);
}
.contact-social svg {
    width: var(--space-7);
    height: var(--space-7);

}

.service-area-details {
    margin-top: var(--space-3);

}
.service-area-details > details summary::before {
    content: 'Show'
}
.service-area-details > details[open=""] summary::before {
    content: 'Hide'
}

.service-area-details summary {
    cursor: pointer;
}

.service-area-copy {
    margin-top: var(--space-2);
}

.service-area-copy p {
    margin: 0;
}

.map-wrapper {
    border: 1px solid var(--neutral-light);
    height: calc( var(--space-10) * 4 ) ;
    overflow: hidden;
    position: relative;
}

.map-wrapper > iframe {
    position: absolute;
    left: 0; top: 0; bottom: 0; right: 0;
    width: 100%;
    height: 100%;
}

/* -------------------------------------------------------------------------- */
/* MARK: Images
*/

figure[data-ratio=""] img {
    object-fit: contain;
    width: 100%;
}

figure[data-crop=""][data-ratio=""] img {
    object-fit: cover;
    width: 100%;
}

figcaption {
    font-style: italic;
    margin-top: 0.5rem;
    text-align: center;
}

figcaption em {
    font-style: normal;
}

/* -------------------------------------------------------------------------- */
/* MARK: Reviews Block
*/

.reviews {
    display: grid;
    gap: var(--space-4);
    list-style: none;
    margin: 0;
    padding: 0;
}

.review {
    display: grid;
    gap: var(--space-4);
    align-content: start;
}

.review-avatar {
    display: flex;
    line-height: 1;
    aspect-ratio: 1;
    border-radius: 50%;
    background-color: var(--neutral-bg);
    color: var(--neutral-mid);
    width: var(--space-10);
    align-items: center;
    justify-content: center;
}



/* random reviews variant */

.random-reviews {
    background-color: var(--neutral-bg);
    gap: 0;
}
.random-reviews .review {
    padding: var(--space-6) var(--space-4);
}
.random-reviews .review-avatar {
    background-color: var(--white);
}
.random-reviews-cta {
    display: flex;
    padding: var(--space-6);
    text-align: center;
}





/* -------------------------------------------------------------------------- */
/* MARK: Gallery Block
*/

.gallery__ul {
    --galleryGap: 1rem;
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: var(--galleryGap);
    justify-content: center;
    list-style: none;
    margin: 0;
    padding: 0;
    width: 100%;
    max-width: 100%;
}

.gallery__li {
    /* default to 2 per row, since that's the min required */
    --itemsPerRow: 2;
    --itemWidth: calc(100% / var(--itemsPerRow));
    --itemGap: calc(( var(--galleryGap) * (var(--itemsPerRow) - 1) / var(--itemsPerRow) ));
    width: calc( var(--itemWidth) - var(--itemGap));
}

.gallery__ul.count-3 .gallery__li {
    --itemsPerRow: 1;
}

/* -------------------------------------------------------------------------- */
/* MARK: Forms
*/

.uniform__potty {
    position: absolute;
    left: -9999px;
}

.uniform-errors {
    background-color: rgb(255, 233, 237);
    border: 1px solid rgb(255, 189, 189);
    border-radius: var(--radius-xs);
    padding: var(--space-3);
}


.rtbform label {
    display: block;
    line-height: 1.2;
    margin-bottom: var(--space-1);
}

.rtbform {
    display: grid;
    gap: var(--space-4);
}

.rtbform > h3 {
    margin: var(--space-6) 0 0 0;
}
.rtbform > h3:first-of-type {
    margin: 0;
}

.rtbform > .row:last-of-type {
    margin-top: var(--space-6);
}


.rtbform input:not([type="submit"]),
.rtbform textarea {
    -webkit-appearance: none;
    appearance: none;
    background: var(--neutral-bg);
    border-radius: var(--radius-xs);
    border: 1px solid var(--neutral-light);
    display: block;
    font-family: 'font-primary';
    font-weight: 400;
    font-size: var(--text-base);
    height: auto;
    line-height: 1;
    margin: 0;
    padding: var(--space-2);
    width: 100%;
    box-shadow: none;
}
.rtbform textarea {
    min-height: var(--space-10);
}

.rtbform input::placeholder,
.rtbform textarea::placeholder {
    color: var(--neutral-mid);
}

.rtbform input[type="submit"] {
    display: block;
    max-width: 50%;
}



/* -------------------------------------------------------------------------- */
/* MARK: Footer CTA
*/

.footer-cta {
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    padding: 0 0 var(--space-8) 0;
    position: relative;
    z-index: 2;
}
.footer-cta-wrap {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}
.footer-cta-wrap > * {
    margin: 0;
}
.footer-cta-text {
    max-width: 40ch;
}
.footer-cta-btn {
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
}

/* -------------------------------------------------------------------------- */
/* MARK: Footer CTA
*/

.footer-wrap {
    position: relative;
}
.footer {
    color: white;
    padding: var(--space-8) 0;
}
.footer-inner {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    margin-top: var(--space-8);
    position: relative;
    z-index: 2;
}
.footer-nav-wrap {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}
.footer h3 {
    color: var(--primary-mid);
    font-weight: 600;
    font-size: var(--text-sm);
    letter-spacing: 1px;
    line-height: 1.2;
    margin-bottom: var(--space-2);
    text-transform: uppercase;
}
.footer ul {
    list-style: none;
    padding: 0;
}
.footer a {
    color: white;
    text-decoration-color: rgba(255, 255, 255, 0.3);
    text-decoration-thickness: 1px;
}
.footer-address {
    justify-content: space-between;
    display: flex;
    gap: var(--space-4);
    flex-direction: column;
}
.footer-address > * {
    margin: 0;
}
.footer-social {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--space-1);
    margin-top: var(--space-1);
}
.footer-social svg {
    width: var(--space-6);
    height: var(--space-6);
}
.footer-footer {
    display: flex;
    font-size: var(--text-xxs);
    margin-block: var(--space-4);
    justify-content: space-between;
}
.footer-footer, .footer-footer a {
    color: var(--white);
    text-decoration-color: inherit
}

/* -------------------------------------------------------------------------- */
/* MARK: Search Modal
*/

.search-modal {
    cursor: zoom-out;
    display: none;
    position: fixed;
    z-index: 1000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: auto;
    background-color: #282E38ee;
}
.search-modal-content {
    cursor: default;
    background-color: var(--neutral-bg);
    border-radius: var(--radius-xs);
    margin: auto;
    padding: var(--space-4);
    position: relative;
    width: 40%;
    min-width: 18.75rem;
    max-width: 37.5rem;
}
.search-close {
    background-color: var(--neutral-light);
    position: absolute;
    top: -0.75rem;
    right: -0.75rem;
    color: var(--neutral);
    font-size: 30px;
    height: 30px;
    width: 30px;
    font-weight: bold;
    line-height: 28px;
    cursor: pointer;
    text-align: center;
    border-radius: 50%;
}
.modal-hidden {
    display: none !important;
}

/* -------------------------------------------------------------------------- */
/* MARK: Search Forms
*/

.search-page-form-wrap {
    max-width: 54rem;
}

.search-form {
    display: flex;
    justify-content: start;
    width: 100%;
}
.search-form-text {
    width: 80%;
    font-size: var(--text-md);
}
.search-form-btn {
    width: 20% !important;
}

.footer-search-wrap {
    max-width: 25rem;
}

.footer-search-wrap .search-form-text {
    font-size: var(--text-sm) !important;
}

.search-info {
    margin-top: var(--space-4);
}


/* -------------------------------------------------------------------------- */
/* MARK: Helpers
*/

#top-link	{
	background-color: rgba(0,0,0,0.5);
    border: 1px solid var(--neutral-dark);
	border-radius: 50%;
	bottom: var(--space-1);
	color: #fff;
	display: none;
	height: 40px;
	line-height: 1 !important;
	padding: 10px;
	position: fixed;
	right: var(--space-4);
	text-decoration: none;
	transition: background-color 0.3s ease-in-out;
	width: 40px;
	z-index: 100;
}

#top-link:hover	{
	background-color: rgba(0,0,0,0.9);
}

.trim > :first-child    { margin-top: 0; }
.trim > :last-child     { margin-bottom: 0; }

.screen-reader-text     { border: 0; clip: rect(1px, 1px, 1px, 1px); clip-path: inset(50%); height: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute !important; width: 1px; word-wrap: normal !important; }