/* -------------------------------------------------------------------------- */
/* RTB-MAIN.CSS (c) richardthebrave.com ------------------------------------- */

:root {

    --ratio: auto;

    --primary-bg:       #F2FCEE;
    --primary-light:    #C8F1BB;
    --primary-mid:      #95DF7E;
    --primary:          #509E38;
    --primary-dark:     #3A7C26;

    --secondary-bg:     #F5F6FA;
    --secondary-light:  #DBDEEE;
    --secondary-mid:    #969FD6;
    --secondary:        #3A4060;
    --secondary-dark:   #31354B;

    --accent-bg:        #F0F9FC;
    --accent-light:     #D7EDF4;
    --accent-mid:       #95D4E9;
    --accent:           #65AAC1;
    --accent-dark:      #00709B;

    --neutral-bg:       #f3f3f3;
    --neutral-light:    #ddd;
    --neutral-mid:      #aaa;
    --neutral:          #777;
    --neutral-dark:     #444;

    --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 */

    /* https://utopia.fyi/clamp/calculator/?a=360,1440,10%E2%80%9412|15%E2%80%9417|17%E2%80%9419|21%E2%80%9426|27%E2%80%9436|36%E2%80%9448|44%E2%80%9464&p=text */
    /* 360px -> 1440px */

    --text-xs: clamp(0.625rem, 0.5833rem + 0.1852vw, 0.75rem);       /* 10->12px .text-xs */
    --text-sm: clamp(0.9375rem, 0.8958rem + 0.1852vw, 1.0625rem);    /* 15->17px .text-sm */
    --text-base: clamp(1.0625rem, 1.0208rem + 0.1852vw, 1.1875rem);  /* 17->19px .text-base */
    --text-md: clamp(1.3125rem, 1.2083rem + 0.463vw, 1.625rem);      /* 21->26px .text-md */
    --text-lg: clamp(1.6875rem, 1.5rem + 0.8333vw, 2.25rem);         /* 27->36px .text-lg */
    --text-xl: clamp(2.25rem, 2rem + 1.1111vw, 3rem);                /* 36->48px .text-xl */
    --text-xxl: clamp(2.75rem, 2.3333rem + 1.8519vw, 4rem);          /* 44->64px .text-xxl */

    --radius-xxs: calc(var(--space-1) * 0.4 );
    --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: 600; }
em                                { font-style: italic; }
:focus:not(:focus-visible)        { outline: none; box-shadow: none; }
:focus-visible                    { outline: none; box-shadow: 0 0 0 3px var(--accent-mid); }

/* 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;
    }
}

/* -------------------------------------------------------------------------- */
/* MARK: Fonts
*/

/* Public Sans Var */
@font-face {
    font-family: 'font-primary';
    src:    url('/assets/fonts/public-sans-var/public-sans-var.woff2') format('woff2-variations'),
            url('/assets/fonts/public-sans-var/public-sans-var.ttf') format('truetype-variations');
    font-weight: 100 900;
    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; }
.font-primary-900 { font-family: 'font-primary', sans-serif; font-style: normal; font-weight: 900; }

/* Public Sans Var Italic */
@font-face {
    font-family: 'font-primary';
    src:    url('/assets/fonts/public-sans-var/public-sans-var-italic.woff2') format('woff2-variations'),
            url('/assets/fonts/public-sans-var/public-sans-var-italic.ttf') format('truetype-variations');
    font-weight: 100 900;
    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; }
.font-primary-900i { font-family: 'font-primary', sans-serif; font-style: italic; font-weight: 900; font-style: italic; }


/* .theme--green {
    background-color: var(--primary-bg);
}
.theme--navy {
    background-color: var(--secondary-bg);
}
.theme--aqua {
    background-color: var(--accent-bg);
}
.theme--green h1 {
    color: var(--primary);
}
.theme--navy h1 {
    color: var(--secondary);
}
.theme--aqua h1 {
    color: var(--accent);
} */

/* -------------------------------------------------------------------------- */
/* 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); }

/* -------------------------------------------------------------------------- */
/* MARK: Typography 
*/

h1, h2, h3, h4, h5, h6, p, ul, ol {
  margin-bottom: var(--space-3);
}

h1, h2, h3, h4, h5, h6 {
    font-weight: 400;
    line-height: 1.3;
}

.text-xxl       { font-size: var(--text-xxl); letter-spacing: -2px; }
.text-xl, h1    { font-size: var(--text-xl); letter-spacing: -1px }
.text-lg, h2    { font-size: var(--text-lg); letter-spacing: -1px }
.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; }


.list-block ul > li :last-child,
.intro-col ul > li :last-child,
.list-block ol > li :last-child,
.intro-col ol > li :last-child {
    margin: 0;
}

.list-block ul > li,
.intro-col ul > li {
    margin-bottom: var(--space-1);
}
.list-block ol > li,
.intro-col ol > li {
    margin-bottom: var(--space-4);
}

.list-block ul > li:last-of-type,
.intro-col ul > li:last-of-type,
.list-block ol > li:last-of-type,
.intro-col ol > li:last-of-type {
    margin: 0;
}


/* -------------------------------------------------------------------------- */
/* MARK: Links
*/

a           { color: var(--accent-dark); text-decoration-color: var(--accent); text-underline-offset: 0.2em; text-decoration-thickness: 0.1em; }
a:hover     { color: var(--primary); text-decoration-color: currentColor; }
a:active    { color: var(--accent-dark); text-decoration-color: currentColor; }

.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);
    border-radius: var(--radius-xs);
    display: inline-block;
    height: var(--space-5);
    width: var(--space-5);
}


/* -------------------------------------------------------------------------- */
/* MARK: Buttons
*/

.btn    {
    background-color: var(--primary);
    border: 1px solid transparent;
    border-radius: var(--radius-xs);
    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: Disclosures (Details/Summary)
*/

details {
    border: 1px solid var(--neutral-light);
    border-radius: var(--radius-xs);
    display: block;
}
summary {
    padding: var(--space-4);
    cursor: pointer;
    font-size: var(--text-base);
    font-weight: 400;
    display: block;
    line-height: 1.3;
}
details .drawer {
    padding: 0 var(--space-4) var(--space-4) calc(var(--space-6) + 2rem);
}

.accordion {
    background-color: var(--neutral-bg);
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    border-left: var(--space-1) solid var(--neutral-light);
}

.accordion summary {
    padding-left: calc(var(--space-6) + 2rem);
    position: relative;
}

.accordion summary::before {
    content: '+';
    position: absolute;
    left: var(--space-3);
    top: 50%;
    margin-top: -1rem;
    font-size: var(--text-lg);
    color: var(--neutral);
    font-weight: 300;
    line-height: 0.9;
    height: 2rem;
    width: 2rem;
    text-align: center;
}

.accordion[open=""] {
    background-color: white;
}
.accordion[open=""] summary::before {
    content: '–'
}

/* -------------------------------------------------------------------------- */
/* MARK: Content & Layout Grid
*/

#page {
    padding-bottom: var(--space-4);
}

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;
}

.layout__inner {
    display: grid;
    gap: var(--space-4);
}
.layout__inner > * {
    margin-block: 0;
}

.layout__inner > h2:not(:first-child),
.intro-col > h2:not(:first-child),
.layout__inner > h3:not(:first-child),
.intro-col > h3:not(:first-child) {
    padding-top: var(--space-4);
}

/* -------------------------------------------------------------------------- */
/* 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 {
    color: rgba(255, 255, 255, 0.5);
    padding: var(--space-1) 0;
}

.courtesy-nav .icon {
    display: inline-block;
    width: 16px;
    padding-top: 2px;
    height: 16px;
}

.courtesy-nav ul {
    display: flex;
    gap: var(--space-4);
    list-style: none;
    margin: 0;
    padding: 0;
}

.courtesy-nav a {
    color: white;
    text-decoration: none;
}

.courtesy-nav a:hover {
    text-decoration: underline;
}

/* -------------------------------------------------------------------------- */
/* MARK: Header
*/

.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(--secondary-dark);
    padding: 0;
}

.mobile-nav__btn:hover {
    background-color: transparent;
    color: var(--secondary-dark);
}

.mobile-nav__label {
    padding-right: 3px;
}

/* -------------------------------------------------------------------------- */
/* MARK: Page Title
*/

.page-title {
    border-radius: var(--radius-md);
    border: 1px solid var(--neutral-light);
    margin-bottom: var(--space-4);
    padding: var(--space-10) 0 0 0;
}

.page-title-copy {
    background-color: white;
    border: 1px solid var(--neutral-light);
    border-bottom-width: 0;
    border-radius: var(--radius-md) var(--radius-md) 0 0;
    padding: var(--space-6);
    position: relative;
}

.page-title-copy::after {
    content: '';
    position: absolute;
    height: 4px;
    background-color: white;
    left: 0; right: 0; bottom: -2px;
}

.page-title-pill {
    background-color: var(--neutral);
    border-radius: var(--radius-xs);
    color: white;
    font-size: var(--text-sm);
    line-height: 1;
    padding: var(--space-1) var(--space-2);
    position: absolute;
    top: calc(-1 * var(--space-3));
    left: var(--space-6);
    text-decoration: none;
}

.page-title-pill:hover {
    color: white;
}

.theme--green .page-title { background-color: var(--primary-bg); border-color: var(--primary-light); }
.theme--navy .page-title { background-color: var(--secondary-bg); border-color: var(--secondary-light); }
.theme--aqua .page-title { background-color: var(--accent-bg); border-color: var(--accent-light); }

.theme--green .page-title-copy { border-color: var(--primary-light); }
.theme--navy .page-title-copy { border-color: var(--secondary-light); }
.theme--aqua .page-title-copy { border-color: var(--accent-light); }

.theme--green .page-title-pill { background-color: var(--primary);  }
.theme--navy .page-title-pill { background-color: var(--secondary);  }
.theme--aqua .page-title-pill { background-color: var(--accent);  }

.page-title-lede {
    font-weight: 350;
    max-width: 60ch;
}

/* -------------------------------------------------------------------------- */
/* MARK: Intro Block for Service Pages
*/

.intro-with-nav {
    align-items: start;
    display: grid;
    gap: var(--space-4);
}

.intro-main {
    display: grid;
    gap: var(--space-4);
    grid-column: 1 / 9;
    padding-right: 10%;
}

.intro-main > * {
    margin-block: 0;
}

.intro-sidebar {
    border: 1px solid var(--neutral-light);
    border-radius: var(--radius-xs);
    padding: var(--space-2);
    grid-column: 9 / -1;
}

.sidebar-nav-ul {
    list-style: none;
    margin: 0;
    padding: 0;
}
.sidebar-nav-link {
    border: 1px solid var(--neutral-light);
    border-radius: var(--radius-xs);
    color: var(--neutral);
    display: block;
    padding: var(--space-1);
    text-decoration: none;
}
.sidebar-nav-title {
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
}
.sidebar-nav-title .sidebar-nav-link {
    border-color: transparent !important;
}

.sidebar-nav-link.active {
    font-style: italic;
}
.sidebar-nav-link:hover {
    border-color: var(--neutral-dark);
    color: var(--neutral-dark);
}

.theme--green .intro-sidebar { background-color: var(--primary-bg); border-color: var(--primary-bg); }
.theme--navy .intro-sidebar { background-color: var(--secondary-bg); border-color: var(--secondary-bg); }
.theme--aqua .intro-sidebar { background-color: var(--accent-bg); border-color: var(--accent-bg); }

.theme--green .sidebar-nav-link    { border-color: var(--primary-light); color: var(--primary-dark); }
.theme--navy .sidebar-nav-link     { border-color: var(--secondary-light); color: var(--secondary-dark); }
.theme--aqua .sidebar-nav-link     { border-color: var(--accent-light); color: var(--accent-dark); }

.theme--green .sidebar-nav-link.active    { background-color: var(--primary-light);     }
.theme--navy .sidebar-nav-link.active     { background-color: var(--secondary-light);   }
.theme--aqua .sidebar-nav-link.active     { background-color: var(--accent-light);      }

.theme--green .sidebar-nav-link:hover    { border-color: var(--primary-dark); color: var(--primary-dark); }
.theme--navy .sidebar-nav-link:hover     { border-color: var(--secondary-dark); color: var(--secondary-dark); }
.theme--aqua .sidebar-nav-link:hover     { border-color: var(--accent-dark); color: var(--accent-dark); }

/* -------------------------------------------------------------------------- */
/* MARK: Table of Contents
*/

.table-of-contents {
    margin-top: var(--space-6);
}

.table-of-contents summary {
    text-transform: uppercase;
    letter-spacing: 1px;
    font-size: var(--text-sm);
    font-weight: 600;
}

/* -------------------------------------------------------------------------- */
/* 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);
    border-radius: var(--radius-xs);
    color: var(--neutral-dark);
    display: grid;
    align-content: start;
    gap: var(--space-1);
    height: 100%;
    padding: var(--space-4);
    text-decoration: none;
}

.portal-li-link > * {
    margin: 0;
}

.portal-li-title {
    text-wrap: balance;
}

.portal-li-sidekick {
    color: var(--neutral);
    line-height: 1.3;
}

/* -------------------------------------------------------------------------- */
/* MARK: Banner Block
*/

.banner {
    background-color: var(--secondary-bg);
    border-radius: var(--radius-xs);
    display: grid;
    grid-template-areas: "stack";
    overflow: hidden;
    position: relative;
}

.banner > * {
    grid-area: stack;
    position: relative;
}

.banner-has-img::after {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 60%;
    background: linear-gradient(90deg, rgba(0,0,0,0.5) 25%, rgba(0,0,0,0) 75%); 
}

.banner-text {
    display: flex;
    flex-direction: column;
    grid-gap: var(--space-4);
    padding: var(--space-6);
    position: relative;
    z-index: 2;
}

.banner-has-img .banner-text {
    color: white;
}

.banner-text > * {
    margin-block: 0;
}

.banner-title {
    max-width: 36ch;
}

.banner-image img {
    object-fit: cover;
    height: 100%;
    width: 100%;
    position: absolute;
    top: 0;right: 0;bottom: 0;left: 0;
    filter: brightness(0.7) saturate(1.2);
}

.fw-badge {
    line-height: 1;
}

.fw-badge span {
    background-color: var(--secondary-light);
    display: inline-block;
    font-size: var(--text-sm);
    letter-spacing: 1px;
    padding: var(--space-1);
    text-transform: uppercase;
    border-radius: var(--radius-xs);
}

.banner-has-img .fw-badge span {
    background-color: var(--primary);
}

/* -------------------------------------------------------------------------- */
/* MARK: Two-Column Block
*/

.two-column {
    display: grid;
    gap: var(--space-6);
}
.two-column-text {
    align-content: start;
    display: grid;
    gap: var(--space-4);
}

.two-column-text > * {
    margin: 0;
}

.two-column-image {
    overflow: hidden;
    max-width: 16rem;
}

.two-column-image img {
    width: 100%;
}


/* -------------------------------------------------------------------------- */
/* MARK: Tax Forms
*/

.tax-forms .portal-ul  {
    grid-template-columns: repeat(1, 1fr);
    gap: var(--space-1);
}

.tax-forms .portal-li-link {
    align-items: center;
    display: grid;
    gap: var(--space-2);
    padding: var(--space-3);
}

.tax-forms .portal-li-link > * {
    margin: 0;
}



/* -------------------------------------------------------------------------- */
/* MARK: Contact Page
*/

.contact-cards {
    display: grid;
    gap: var(--space-4);
    text-align: center;
}

.contact-cards > ul {
    list-style: none;
    margin: 0;
}

.contact-card {
    background-color: var(--primary-bg);
    border-radius: var(--radius-md);
    border: 1px solid var(--neutral-light);
    padding: var(--space-6) var(--space-4);
}

.contact-card:nth-child(2) {
    background-color: var(--secondary-bg);
}

.contact-card:nth-child(3) {
    background-color: var(--accent-bg);
}

.map-wrapper {
    border: 1px solid var(--neutral-light);
    border-radius: var(--radius-xs);
    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: 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 .row {

}

.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;
    width: 100%;
}

/* -------------------------------------------------------------------------- */
/* MARK: Footer
*/

.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-wrap {
    position: relative;
}

.footer {
    color: white;
    border-radius: var(--radius-md);
    padding: var(--space-8) 0;
}

.footer-trio {
    position: absolute;
    right: var(--space-4); bottom: 0;
    width: calc(100% - (var(--space-4) * 4));
    max-width: 95%;
    grid-area: auto !important;
    border-bottom-right-radius: var(--radius-md);

}

.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(--accent);
    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.4);
    text-decoration-thickness: 1px;
}

.footer-footer {
    display: flex;
    font-size: var(--text-xs);
    margin-top: var(--space-4);
    justify-content: space-between;
}

.footer-footer, .footer-footer a {
    color: var(--neutral)
}

footer .search-form {
    display: flex;
    gap: var(--space-2);
    margin-top: var(--space-4);
    position: relative;
    z-index: 2;
}

footer .search-form input {
    font-size: var(--text-xs);

}

footer .search-form input:not([type="submit"]) {
    background-color: var(--accent-bg) !important;
    border: 0 !important;
    border-radius: var(--radius-xs);
    padding: var(--space-1) var(--space-2)
}



/* -------------------------------------------------------------------------- */
/* MARK: Search
*/

.search-modal {
    cursor: zoom-out;
    display: none;
    position: fixed;
    z-index: 1000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: auto;
    background-color: rgba(101, 170, 193, 0.85);
}

.search-modal-content {
    cursor: default;
    background-color: white;
    border-radius: var(--radius-xs);
    box-shadow: 0 var(--space-1) var(--space-8) rgba(0, 0, 0, 0.2);
    margin: auto;
    max-width: 100%;
    min-width: 18.75rem;
    padding: var(--space-6);
    position: relative;
    width: 60%;
}

.search-modal .search-form {
    display: flex;
    flex-wrap: nowrap;
    gap: var(--space-3);
    justify-content: start;
    width: calc(100% - 60px);
}
.search-modal .search-form__text {
    max-width: none;
    width: 100%;
}

.search-close {
    background-color: var(--neutral-bg);
    border-radius: 50%;
    position: absolute;
    top: 50%;
    margin-top: -20px;
    right: 20px;
    color: var(--neutral);
    font-size: 40px;
    height: 40px;
    width: 40px;
    font-weight: bold;
    line-height: 39px;
    cursor: pointer;
    text-align: center;
}

.modal-hidden {
    display: none !important;
}


/* -------------------------------------------------------------------------- */
/* MARK: Helpers
*/

#top-link	{
	background-color: rgba(0,0,0,0.5);
    border: 1px solid var(--neutral-dark);
	border-radius: var(--radius-xs);
	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; }