@import url(https://use.typekit.net/xdd8tlo.css);
@import url(https://use.typekit.net/ncg6xmr.css);


:root {
    --light-blue: #D8EFF5;
    --blue: #0095B5;
    --med-blue: #0C7096;
    --dark-blue: #164B74;
    --accent-blue: #09648B;
    --navy: #002F53;
    --yellow: #F6C708;
    --red: #AA0F4D;
    --orange: #FEA53F;
    --black: #000000;
    --green: #ABD03F;
    --white: #FFFFFF;
    --light-grey: #E5E8E9;
    --light-grey2: #D6DCDF;
    --medium-grey: #ABABAC;
    --grey: #7E7E7E;
    --dark-grey: #444446;
    --dark-red: #820025;
    --tax-assessment: #AEECEA;
    --utilities-water: #CAE8FF;
    --waste-recycling: #C0F4C3;
    --animal-licensing: #DDD5D3;
    --business-owners: #FFF595;
    --programs-classes: #D4C6E8;
    --online-payments: #E3C0C3;
    --permits-construction: #FFEEC1;
    --closures-repairs: #FFBB86;
    --airdrie-transit: #F8CBFF;
    --rentals-bookings: #A5DCBA;
    --report-issue: #FFC2C2;
    --public-participation: #DCF8AE;
    --accent-gold: #FFD15C;
    --accent-light-blue: #95D2FF;
    --accent-light-yellow: #FFEF5C;
    --accent-brown: #B5ADAB;
    --accent-turquoise: #93D1D0;
    --accent-teal: #00AFAD;
    --accent-dark-green: #198223;
    --accent-blue-black: #001B3F;
    --accent-dark-orange: #F26522;
    --accent-purple: #7D0069;
    --accent-mid-green: #9CDE9F;
    --tb-padding: 30px;
    --lr-padding: 22px;
    --tb-margin: 40px;
    --lr-margin: 22px;
    --gutter: 20px;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

.grecaptcha-badge { 
    visibility: hidden; 
}

.content_editable_form_field {
    display: block;
}

body {
    font-family: 'arboria', sans-serif;
    font-size: 16px;
    line-height: 24px;
}
body.loading::before {
    position: fixed;
}
#loader {
    display: none;
    position: fixed;
    z-index: 10001;
    width: 100vw;
    height: 100vh;
    justify-content: center;
}
    #loader svg {
        width: 25vw;
        max-width: 200px;
    }
        #loader svg circle {
            animation-iteration-count: infinite;            
            animation-timing-function: linear;
            animation-duration: 3s;
        }
        #loader svg circle:nth-of-type(1) {
            animation-name: circlemove1;
        }
        #loader svg circle:nth-of-type(2) {
            animation-name: circlemove2;
        }
        #loader svg circle:nth-of-type(3) {
            animation-name: circlemove3;    
        }
        #loader svg circle:nth-of-type(4) {
            animation-name: circlemove4;
        }
        #loader svg circle:nth-of-type(5) {                  
            animation-name: circlemove5;
            transform-origin: 77px 195px; 
        }
    #loader::after {
        position: fixed;
        content: '';
        display: block;
        height: 100vh;
        width: 100vw;
        background: rgba(0, 0, 0, 0.8);
    }
    #loader #loaderElements {
        z-index: 1;
        color: white;
        display: flex;
        justify-content: center;
        align-items: center;
        flex-direction: column;

        .loader_text {
            text-shadow: -1px 0 black, 0 1px black, 1px 0 black, 0 -1px black;
            margin: 20px;
            text-align: center;
        }
    }

@keyframes circlemove1 {
    0% {
        transform: translate(0, 0);
    }
    12.5% {
        transform: translate(0, 3px);
    }
    25% {
        transform: translate(0, -15px);
    }
    37.5% {
        transform: translate(0, 3px);
    }
    50%, 82.5% {
        transform: translate(0, 0);
        fill: #0D7B93;
    }
    100% {
        transform: translate(34px, 0);
        fill: #0095B5;
    }    
}

@keyframes circlemove2 {
    0%, 12.5% {
        transform: translate(0, 0);
    }
    25% {
        transform: translate(0, 3px);
    }
    37.5% {
        transform: translate(0, -15px);
    }
    50% {
        transform: translate(0, 3px);
    }
    62.5%, 82.5% {
        transform: translate(0, 0);
        fill: #0095B5;
    }
    100% {
        transform: translate(34px, 0);
        fill: #3CB7D2;
    }    
}

@keyframes circlemove3 {
    0%, 25% {
        transform: translate(0, 0);
    }
    37.5% {
        transform: translate(0, 3px);
    }
    50% {
        transform: translate(0, -15px);
    }
    62.5% {
        transform: translate(0, 3px);
    }
    70%, 82.5% {
        transform: translate(0, 0);
        fill: #3CB7D2;
    }
    100% {
        transform: translate(34px, 0);
        fill: #6ACFE5;
    }   
}

@keyframes circlemove4 {
    0%, 37.5% {
        transform: translate(0, 0);
    }
    50% {
        transform: translate(0, 3px);
    }
    62.5% {
        transform: translate(0, -15px);
    }
    70% {
        transform: translate(0, 3px);
    }
    82.5% {
        transform: translate(0, 0);
        fill: #6ACFE5;
    }
    100% {
        transform: translate(34px, 0);
        fill: #A0EAFA;
    }    
}

@keyframes circlemove5 {
    0%, 50% {
        transform: translate(0, 0);
    }
    62.5% {
        transform: translate(0, 3px);
    }    
    65% {
        transform: translate(0, 0) rotate(0);
    } 
    80% {
        transform: translate(0, -50px) rotate(-90deg);
    }   
    90% {
        fill: #A0EAFA;
    }
    100% {
        fill: #0D7B93;
        transform: translate(0, 0) rotate(-180deg);
    }      
}
        

body.loading #loader {
    display: flex;
}

div.loading {
    position: relative;
    min-height: 200px;
}

div.loading::before {
    position: absolute;
    content: '';
    display: block;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.8);
    z-index: 1;
}

div.loading::after {
    content: url("/assets/myairdrie/img/mini_loader.svg");;
    display: flex;
    z-index: 2;
    justify-content: center;
    align-items: center;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
}

body:not(.supports_push) .requires_push_support, body.push_enabled .push_element {
    display: none;
}

/* Headers */
h1 {
    font-family: 'urbane-rounded', sans-serif;
    font-size: 22px;
    font-weight: 300;
    line-height: 32px;
    margin-bottom: 14px;
}

h2, .expanding-section__title {
    font-size: 20px;
    font-weight: 700;
    line-height: 28px;
    margin-bottom: 11px;
}

h3 {
    font-size: 18px;
    font-weight: 700;
    line-height: 26px;
    margin-bottom: 10px;
}

.content_block.collapsible .expanding-section__title,
.expanding-section--highlight-card .expanding-section__title,
.content_custom .expanding-section--bordered .expanding-section__title {
    font-size: 18px;
    font-weight: 700;
    line-height: 26px;
}

h4, .h4 {
    font-size: 16px;
    font-weight: 700;
    line-height: 24px;
    margin-bottom: 22px;
}

h5 {
    font-size: 14px;
    font-weight: 400;
    line-height: 22px;
    margin-bottom: 20px;
}

h6 {
    font-size: 13px;
    font-weight: 700;
    line-height: 21px;
    margin-bottom: 19px;
}

/* List */
ol:not(:last-child, :has(+hr)),
ul:not(:last-child, :has(+hr)) {
    margin-bottom: 46px;
}

li {
    margin-bottom: 14px;
    margin-left: 2em;
}

li:last-child {
    margin-bottom: 0;
}

.no-marker-list {
    list-style-type: none;    
}

.no-marker-list li {
    margin-left: 0;
}

ul.subsection-list {
    margin-bottom: 24px;
}

/* Links */
a,
.btn-link {
    font-family: 'urbane-rounded', sans-serif;
    font-size: 14px;
    color: var(--dark-blue);
    font-weight: 500;
    line-height: 24px;
    text-decoration: underline;
    text-underline-offset: 17%;
    text-decoration-skip-ink: auto;
    letter-spacing: 0.4px;
    text-align: left;
}

a:hover,
.btn-link:hover {
    color: var(--med-blue);
}

a:not(.btn, .site-header__link, .dashboard-menu__link):visited {
    color: var(--accent-purple);
}

.navy-bg a {
    color: var(--white);
}

.navy-bg a:hover {
    color: var(--blue);
}

.navy-bg a:not(.btn):visited {
    color: var(--light-blue);
}

.link-icon-container {
    display: inline-flex;
    align-items: baseline;
    gap: 5px;
}

.link-icon {
    flex-shrink: 0;
    position: relative;
    top: 3px;
    width: 14px;
    height: 14px;
}

.link-icon path {
    fill: currentcolor;
}

.settings--communication,
.alerts-reminders {
    & .link-icon-container {
        gap: 10px;
    }

    & .link-icon {
        width: 22px;
        height: unset;
    }
}

small a,
small .btn-link {
    font-size: 12px;
}

/* Horizonal rule */
hr {
    width: 100%;
    height: 1px;
    background-color: var(--light-grey2);
    border: none;
    margin-top: 25px;
    margin-bottom: 25px;
    display: inline-block;
}

hr.section-divider {
    margin-top: 30px;
    margin-bottom: 30px;
}

.light-blue-bg hr,
.light-grey-bg hr,
.expanding-section--highlight-card hr {
    background-color: var(--white);
}

/* Containers */
.global-container {
    display: flex;
    flex-direction: column;
    width: 100%;
    height: 100%;
    min-height: 100vh;
    overflow-x: hidden;
}

main {
    flex-grow: 1;    
}

.center-container {
    width: 100%;
    margin: 0;
}

.global-container:not(.wizard) .content_block:not(.content_form:has(form), :has(.message-block)),
.content_block.content_form:has(form) > h2 {    
    padding-left: var(--lr-padding);
    padding-right: var(--lr-padding);
}

.global-container:not(.wizard) .content_block:not(.content_form:has(form), :has(.message-block), :has(.expanding-section.no-margin-top:first-child)),
.content_block.content_form:not(.no_margin):has(> h2) {
    margin-top: var(--tb-margin);
}

.breadcrumb-container +.content_block {
    margin-top: 30px !important;
}

.content_block p,
.modal__content p {
    margin-bottom: 22px;
}

.content_block p:last-child,
.content_block p:has(+hr),
.modal__content p:last-child,
.modal__content p:has(+hr) {
    margin-bottom: 0;
}

.content_block p:has(+ *:not(p, hr, ul, ol)),
.modal__content p:has(+ *:not(p, hr, ul, ol)) {
    margin-bottom: 46px;
}

.content_block p:has(+ div),
.modal__content p:has(+ div) {
    margin-bottom: 25px;
}

.two-columns {
    columns: 2;
}

.two-columns li {
    break-inside: avoid;
}

.hide, .forced_hide {
    display: none !important;
}

.text-center {
    text-align: center;
}

.text-right {
    text-align: right;
}

.text-justified {
    text-align: justify;
}

.font-normal {
    font-weight: 400;
}

.margin-top {
    margin-top: var(--tb-margin)!important;
}

.margin-top-half {
    margin-top: calc(var(--tb-margin) / 2)!important;
}

.margin-bottom {
    margin-bottom: var(--tb-margin) !important;
}

.margin-left {
    margin-left: var(--tb-margin)!important;
}

.margin-left-half {
    margin-left: calc(var(--tb-margin) / 2)!important;
}

.margin-right {
    margin-right: var(--tb-margin)!important;
}

.margin-right-half {
    margin-right: calc(var(--tb-margin) / 2)!important;
}

.margin-bottom-half {
    margin-bottom: calc(var(--tb-margin) / 2)!important;
}

.no-margin-top {
    margin-top: 0 !important;
}

.no-margin-bottom {
    margin-bottom: 0 !important;
}
.no-margin-left {
    margin-left: 0!important;
}
.no-margin-right {
    margin-right: 0!important;
}
.no-margin {
    margin: 0!important;
}

.padding-top {
    padding-top: var(--tb-padding)!important;
}

.padding-bottom {
    padding-bottom: var(--tb-padding)!important;
}

.no-padding-top {
    padding-top: 0 !important;
}
.no-padding-bottom {
    padding-bottom: 0 !important;
}
.no-padding-left {
    padding-left: 0!important;
}
.no-padding-right {
    padding-right: 0!important;
}
.no-padding {
    padding: 0!important;
}

.border-top {
    border-top: 1px solid var(--light-grey2);
    margin-top: 25px;
    padding-top: 25px;
}

.border-bottom {
    border-bottom: 1px solid var(--light-grey2);    
    margin-bottom: 25px;
    padding-bottom: 25px;
}

.no-border-top {
    border-top: 0 !important;
}

.no-border-bottom {
    border-bottom: 0 !important;
}

/* Background and color */
.light-blue-bg {
    background-color: var(--light-blue);
}

.light-grey-bg {
    background-color: var(--light-grey);
}

.navy-bg {
    background-color: var(--navy);
    color: var(--white);
}

.blue-bg {
    background-color: var(--blue);
    color: var(--white);
}

.tax-assessment-bg {
    background-color: var(--tax-assessment);
}

.utilities-water-bg {
    background-color: var(--utilities-water);
}

.waste-recycling-bg {
    background-color: var(--waste-recycling);
}

.animal-licensing-bg {
    background-color: var(--animal-licensing);
}

.business-owners-bg {
    background-color: var(--business-owners);
}

.programs-classes-bg {
    background-color: var(--programs-classes);
}

.online-payments-bg {
    background-color: var(--online-payments);
}

.permits-construction-bg {
    background-color: var(--permits-construction);
}

.closures-repairs-bg {
    background-color: var(--closures-repairs);
}

.airdrie-transit-bg {
    background-color: var(--airdrie-transit);
}

.rentals-bookings-bg {
    background-color: var(--rentals-bookings);
}

.report-issue-bg {
    background-color: var(--report-issue);
}

.public-participation-bg {
    background-color: var(--public-participation);
}

.accent-light-blue-bg {
    background-color: var(--accent-light-blue);
}

.accent-light-yellow-bg {
    background-color: var(--accent-light-yellow)
}

.accent-gold-bg {
    background-color: var(--accent-gold);
}

.accent-blue-bg {
    background-color: var(--accent-blue);
    color: var(--white);
}

.accent-purple-bg {
    background-color: var(--accent-purple);
    color: var(--white);
}

.accent-dark-green-bg {
    background-color: var(--accent-dark-green);
    color: var(--white);
}

.orange-bg {
    background-color: var(--orange);
}

.red-bg {
    background-color: var(--red);
    color: var(--white);
}

.dark-grey-bg {
    background-color: var(--dark-grey);
    color: var(--white);
}

.red {
    color: var(--red);
}

/* Site header */
header {
    position: sticky;
    top: 0;
    z-index: 600;
}

.site-header {
    background-color: var(--blue);
    position: relative;
    z-index: 100;
}

.site-header__container {
    display: grid;
    grid-template-columns: auto 1fr;
    grid-auto-columns: auto;
    overflow: hidden;
    margin: 0 auto;
}

.site-header__left {
    padding: 25px 40px 25px 22px;
    display: flex;
    align-items: center;
}

.site-header__right {
    background-color: var(--med-blue);
    position: relative;
    display: flex;
    align-items: center;
    position: relative;
    z-index: 2;
    grid-column: 3;
    padding-right: var(--lr-padding);
}

.site-header__nav::before,
.site-header__right::before {
    content: '';
    position: absolute;
    top: 0;
    left: -200px;
    height: 100%;
    width: 200px;
    background-color: var(--med-blue);
    transform-origin: 100% 0;
    transform: rotate(-51deg);
}

.site-header__title {
     /* Hidden by default on mobile/tablet */
    display: none;
    color: var(--white);
    margin: 0;
}

.site-header__actions {
    display: flex;
    align-items: center;
    gap: 30px;
    font-family: 'urbane-rounded', sans-serif;
    font-size: 14px;
    font-weight: 500;
    line-height: 18px;
    position: relative;
    z-index: 1;
}

.site-header__nav {
    /* Hidden by default on mobile/tablet */
    display: none;
}

.site-header__logo {
    display: block;
    width: 140px;
    height: auto;
}

.site-header__link,
.site-header__link:visited,
.site-header__link:active,
.site-header__link:focus,
.dashboard-menu__link,
.dashboard-menu__link:visited,
.dashboard-menu__link:active,
.dashboard-menu__link:focus {
    color: var(--white);
}

.site-header__link:hover,
.dashboard-menu__link:hover {
    color: #A9E4F3;
}

button.site-header__link--sign-out {
    color: var(--light-blue);
}

.site-header__link,
.site-header__menu {
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--white);
    text-decoration: none;
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    font-family: inherit;
    font-size: inherit;
    font-weight: inherit;
    line-height: inherit;
    letter-spacing: 0.7px;
}

.site-header__icon {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
}

/* Menu text and icon change functionality */
.site-header__menu::after {
    content: 'Menu';
}

.menu-open .site-header__menu::after {
    content: 'Close';
}

.site-header__menu .menu-close-icon,
.menu-open .site-header__menu .menu-icon {
    display: none;
}

.menu-open .site-header__menu .menu-close-icon {
    display: block;
}

/* Dashboard menu */
.dashboard-menu {
    display: none;
}

.dashboard-menu__icon {
    width: 26px;
    height: 26px;
    flex-shrink: 0;
}

.dashboard-menu__title {
    color: var(--white);
    margin-bottom: 0;
}

.dashboard-menu__nav {
    display: flex;
    align-items: center;
    gap: 20px;
    padding: var(--tb-padding) var(--lr-padding);
    background-color: var(--dark-blue);
    position: relative;
    z-index: 500;
    justify-content: space-between;
}

.dashboard-menu__actions {
    display: flex;
    align-items: center;
    gap: 20px;
}

.dashboard-menu__link {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 8px;
    text-decoration: none;
    letter-spacing: 0.7px;
}

.dashboard-menu__link--dashboard,
.menu-open .dashboard-menu__title {
    display: none;
}

.menu-open .dashboard-menu__link p {
    display: block;    
}

.menu-open .dashboard-menu__link--dashboard {
    display: flex;
}

.menu-open .dashboard-menu__actions {
    flex-grow: 1;
    justify-content: space-evenly;
}

/* Navigation */
nav {
    height: 100%;
    display: none;
}

.menu-open nav {
    display: flex;
    flex-direction: column;
}

.nav__section {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 22px;
    justify-content: center;
    padding: 40px var(--lr-padding);
}

.nav__section--secondary {
    flex-direction: column;
    flex-grow: 1;
    justify-content: flex-start;
    background-color: var(--light-blue);
    padding: var(--tb-padding) var(--lr-padding);
}

.nav__section--secondary ul {
    list-style-type: none;    
}

.nav__section--secondary li {
    margin-left: 0;
    margin-bottom: 20px;
}

.nav__link,
.nav__link:visited,
.nav__link:active,
.nav__link:focus {
    color: var(--navy);
    line-height: 20px;
}

/* Footer */
.site-footer {
    background-color: var(--navy);
    color: var(--white);
    padding: 40px var(--lr-padding) 60px;
    display: flex;
    justify-content: space-between;
    gap: 20px;
    margin-top: 50px;
}

.site-footer__links {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.site-footer__link {
    font-size: 14px;
    line-height: 20px;
}

.site-footer__links a,
.site-footer__links a:hover,
.site-footer__links a:visited {
    color: var(--white);
}

.site-footer__brand {
    text-align: right;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: flex-end;
}

.site-footer__logo {
    width: 123px;
    height: auto;
}

.site-footer__copyright {
    margin-bottom: 0;
}

/* Breadcrumb */
.breadcrumb-container {
    text-align: right;
    margin: 17px var(--lr-margin) 0;
}

.breadcrumb-link {
    position: relative;
    padding-left: 15px;
    vertical-align: bottom;
}

.breadcrumb-link::before {
    content: '<';
}

/* Setup wizard */
.global-container:not(.wizard) .content_block:not(.content_form:has(form), :has(.message-block)),
.content_block.content_form > h2 {    
    padding-left: var(--lr-padding);
    padding-right: var(--lr-padding);
}

.wizard-header,
.myairdrie-header {
    background-color: var(--blue);
    position: relative;
    z-index: 100;
    display: flex;
    overflow: hidden;
    flex-direction: column-reverse;
}

.wizard-header__container,
.myairdrie-header__container {
    position: relative;
    margin-left: auto;
    height: 103px;
}

.wizard-header__logo-wrapper,
.myairdrie-header__logo-wrapper {
    position: relative;
    z-index: 2;
    display: flex;
    align-items: center;
    background-color: var(--med-blue);
    height: 103px;
}

.wizard-header__logo-wrapper::before,
.myairdrie-header__logo-wrapper::before {
    content: '';
    position: absolute;
    border-radius: 50%;
    top: 50%;
    left: -20px;
    transform: translateY(-50%);
    width: 165px;
    height: 165px;
    background-color: var(--med-blue);
    z-index: 3;
}

.wizard-header__logo,
.myairdrie-header__logo {
    position: relative;
    margin: 30px var(--lr-margin) 30px 30px;
    display: block;
    z-index: 5;
    width: 180px;
    height: auto;
}

.wizard-header__progress {
    width: 100%;
    background-color: var(--white);
    position: relative;
    z-index: 30;
}

.wizard-header__content {
    position: relative;
    z-index: 1;
    padding: 20px var(--lr-padding);
    display: flex;
    align-items: center;
    gap: 20px;
}

.wizard-header__content h1 {
    margin-bottom: 0;
    color: var(--dark-grey);
    line-height: 30px;
}

.wizard-header__steps {
    display: flex;
    align-items: center;
    gap: 3px;
    position: relative;
}

.wizard-header__step-icon {
    width: 25px;
    height: 25px;
    position: relative;
    z-index: 2;
}

.wizard-header__step-icon--empty {
    width: 25px;
    height: 25px;
    border: 2px solid var(--medium-grey);
    border-radius: 50%;
    background-color: var(--white);
}

.wizard-header__step-line {
    width: 15px;
    height: 2px;
    background-color: var(--medium-grey);
}

.wizard-steps-container {
    text-align: center;
    margin: var(--tb-margin) var(--lr-margin) 0;
}

.wizard-steps__items {    
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    padding: 30px;
}

.wizard-steps__item {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.wizard-steps__item h4 {
    font-weight: 400;
}

.wizard-steps__item:nth-child(-n+2) {
    border-bottom: 1px solid var(--white);
}

.wizard-steps__item:nth-child(odd) {
    padding-right: 20px;
    border-right: 1px solid var(--white);
}

.wizard-steps__item:nth-child(even) {
    padding-left: 20px;   
}

.wizard-steps__item:nth-child(n+3) {
    padding-top: 30px;

    &>h4 {
        margin-bottom: 0;
    }
}

.wizard-steps__icon {
    width: auto;
    height: 28px;
}

.wizard-actions {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 40px;
    padding: 50px var(--lr-padding) 0;
}

.wizard-title-container {
    padding: 0 22px 0 25px;
    background-color: var(--green);
    border-top: 10px solid #93B433;
    height: 65px;
    display: flex;
}

.wizard-title-container__content {
    display: flex;
    align-items: center;
    gap: 15px;
}

.wizard-title-container__icon {
    width: auto;
    height: 25px;
}

.wizard-title-container__heading {
    margin-bottom: 0;
}

.wizard-overview-container {
    margin-top: var(--tb-margin);
    padding: 0 var(--lr-padding);
}

.wizard-overview__items {
    padding: var(--tb-padding) var(--lr-padding);
    margin: 0 calc(var(--lr-margin) * -1);
}

.wizard-overview__header {
    display: flex;
    flex-direction: row;
    gap: 10px;
}

.wizard-overview__icon {
    width: auto;
    height: 24px;
}

/* Setup wizard - favourites */
.services-container--wizard .service-card__message,
.services-container--wizard .remove-favourites-button {
    display: none;
}

.wizard_content_block {
    padding-left: var(--lr-padding);
    padding-right: var(--lr-padding);
}

.services-container--wizard .is-favourite .service-card__message {
    display: flex;
    gap: 10px;
    align-items: flex-start;
}

.services-container--wizard .is-favourite .remove-favourites-button {
    display: block;
}

.services-container--wizard .is-favourite .service-card__grid,
.services-container--wizard .is-favourite .add-favourites-button {
    display: none;
}

.service-card__message h4 {
    margin-bottom: 0;
}

.favourites-save-icon {
    width: 17px;
    height: 17px;
    position: relative;
    top: 5px;
}

/* Dashboard */
.dashboard-news-container {
    display: flex;
    flex-direction: column;
    background-color: var(--light-blue);
}

.dashboard-main-container .services-features-container {
    display: flex;
    flex-direction: column;
    gap: 30px;

    & h3:not(.service-card__title) {
        margin-bottom: 20px;
    }
}

.dashboard-main-container .services-features-container>div:not(:last-child) {
    padding-bottom: 30px;
    border-bottom: 1px solid var(--light-grey2);
}

/* Favourites container */
.title-link-container  {
    display: flex;
    align-items: baseline;
    gap: 35px;
}

.service-icon {
    width: 36px;
    height: 32px;
}

.icon-circle {
    width: 54px;
    height: 54px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.circle-shadow {
    box-shadow: 0px 3px 4px 0px rgba(0, 0, 0, 0.25);
}

.icons-container {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 28px;
    justify-content: space-evenly;
}

.icon-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 14px;
    line-height: 20px;
    max-width: 90px;
}

a.icon-container,
a.icon-container:visited,
a.icon-container:hover,
a.icon-container:focus {
    color: var(--black);
    text-decoration: none;
}

.recent-links-container li::marker,
.utility-bills-list li::marker {
    color: var(--dark-blue);
}

/* Service page */
.service-top-container:not(:has(.banner-container)):not(:has(.service-top-container__grid div)),
.service-top-container__grid:not(:has(div)) {
    display: none;
}

.service-top-container__grid {
    display: grid;       
    grid-template-columns: 1fr;
    gap: var(--tb-margin) var(--gutter);
    margin: var(--tb-margin) var(--lr-margin);
}

.service-top-container__grid .content_block:has(.full-width) {
    grid-column: 1 / -1;
}

/* Service title */
.service-title {
    display: flex;
    align-items: center;
    background-color: var(--navy);
    position: relative;
    overflow: hidden;
}

.service-title__icon-wrapper {
    position: relative;
    padding: 18px 0 18px 22px;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2;
}

.service-title__icon-wrapper::after {
    content: '';
    position: absolute;
    border-radius: 50%;
    right: -22px;
    width: 300%;
    height: 250%;
    background-color: inherit;
    z-index: 1;
}

.service-title__icon {
    z-index: 2;
    width: 40px;
    height: 40px;
}

.service-title__heading {
    color: var(--white);
    margin-bottom: 0;
    margin-left: 22px;
    padding: 22px var(--lr-padding);
    flex-grow: 1;
}

.service-title__action--edit {
    background-color: var(--dark-blue);
    color: var(--white);
    display: flex;
    flex-wrap: nowrap;
    gap: 8px;
    border-radius: 2px 0 0 2px;
    padding: 12px 22px;
}

.service-title__action--edit a,
.service-title__button--edit a:visited {
    color: var(--white);
    text-decoration: underline;
}

.service-title__action--edit .pin-icon {
    width: auto;
    height: 20px;
    align-self: center;
}

.btn.service-title__button {
    color: var(--navy);
    background-color: var(--service-title-background-color);
}

.btn.service-title__button:hover {
    background-color: var(--service-title-hover-color);   
}

/* Page title */
.page-title {
    width: 100%;
    background-color: var(--navy);
}

.page-title__container {
    width: 100%;    
    align-content: center;
    padding: 22px var(--lr-padding);
}

.page-title__icon {
    width: 30px;
    height: 30px;
    margin-right: 15px;
    vertical-align: middle;
}

.page-title__heading {
    color: var(--white);
    display: inline-block;
    vertical-align: middle;
    margin: 0;
}

/* Buttons */
button {
    font: inherit;
    color: inherit;
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
}

.btn:not(.btn-link) {
    display: inline-flex;
    align-items: center;    
    text-decoration: none;
    border-radius: 20px;
    font-family: 'urbane-rounded', sans-serif;
    font-weight: 500;
    letter-spacing: 0.04em;
    box-shadow: 3px 3px 6px rgba(0, 27, 63, 0.25);
    transition: background-color 0.3s ease;
    padding: 13px 22px;
    font-size: 14px;
    line-height: 20px;
    min-height: 20px;
    border: none;
    cursor: pointer;
    gap: 10px;
}

.btn-primary {
    background-color: var(--yellow);
    color: var(--navy);
}

.btn-primary:hover {
    background-color: #E3BA14;
}

.navy-bg .btn-primary:hover {
    background-color: #F9D855;
}

.btn__img {
    height: 20px;
    width: auto;
    flex-shrink: 0;
}

.btn-secondary, .btn.secondary {
    background-color: var(--accent-blue);
    color: var(--white);
}

.btn-secondary:hover, .btn.secondary {
    background-color: #005072;
}

.btn-supporting--green {
    background-color: var(--green);
    color: var(--navy);
}

.btn-supporting--green:hover {
    background-color: #8EBD50;
}

.btn-supporting--navy {
    background-color: var(--navy);
    color: var(--white);
}

.btn-supporting--navy:hover {
    background-color: #0E426A;
}

.btn.btn-tertiary {
    background-color: var(--white);
    color: var(--navy);
    border: 1px solid var(--navy);
}

.btn-tertiary:hover {
    background-color: #E2E5EA;
}

.navy-bg .btn-tertiary {
    background-color: var(--white);
    color: var(--navy);
    border-color: var(--navy);
}

.navy-bg .btn-tertiary:hover {
    background-color: #B0BED0;
}

.btn.btn-alert {
    background: transparent;
    color: var(--navy);
    border: 1px solid var(--navy);
}

.btn-alert:hover {
    position: relative;
}

.btn-alert:hover::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: var(--navy);
    opacity: 0.1;
    border-radius: inherit;
    pointer-events: none;
}

.btn-primary:hover,
.btn-supporting--green:hover,
.btn-tertiary:hover,
.btn-alert:hover {
    color: var(--navy);
}

.btn-secondary:hover,
.btn-supporting--navy:hover {
    color: var(--white);
}

.alert-banner--emergency .btn.btn-alert {
    background-color: var(--white);
    border-color: var(--dark-red);
    color: var(--dark-red);
}

.btn-icon-right {
    flex-direction: row-reverse;
}

/* Icons */
.info_faq::after {
    content: url('/assets/myairdrie/img/icons/navy/information-icon.svg');
    margin-left: 5px;
    width: 13px;
    height: 13px;
}

.credit-card-icon-wrapper {
    display: flex;
    justify-content: center;
    align-items: center;
    align-self: center;
    flex-shrink: 0;
    width: 50px;
    height: 30px;
    background-color: var(--white);
}

.existing_card_choice .credit-card-icon-wrapper {
    width: 40px;
    height: 26px;
}

.credit-card-icon {
    width: 33px;
    height: auto;
}
.existing_card_choice .logo {
    max-height:15px;
    margin-right: 5px;
}

/* Quick Links */
.quick-link {
    display: block;
    background-color: var(--light-grey);
    padding: 16px 22px;
    text-align: center;
    border-radius: 2px;
    width: 100%;
    margin-bottom: 15px;
    break-inside: avoid;
}

.quick-link:hover {
    color: var(--dark-blue);
}

.quick-links-container {
    columns: 2;
    column-gap: 20px;
}

/* Banners */
.banner-wrapper {
    container-type: inline-size;
    container-name: banner;
}

.banner-image {
    width: 100%;    
}

.banner-img {
    width: 100%;
    height: auto;
    display: block;
    box-shadow: 0px 0px 4px 0px rgba(0, 0, 0, 0.45);
}

.banner-container {
    background-color: var(--navy);
}

.banner-content {
    padding: 22px;    
}

.banner-content a:visited {
    color: var(--white);
}

.banner-content h4 {
    color: var(--white);
    font-family: 'arboria', sans-serif;   
    font-weight: 400;
    margin: 0; 
}

.banner-content a {
    color: var(--white);
}

.banner-carousel {
    position: relative;
    overflow: hidden;
    outline: none;
    container-type: inline-size;
    container-name: banner-carousel;
}

.banner-carousel .banner-container {
    display: grid;  
    grid-template-rows: 1fr min-content 50%;
}

.banner-carousel .banner-container .banner-image {
    grid-column: 1;
    grid-row: 1;    
}

.banner-carousel .banner-container .banner-content {
    grid-column: 1;
    grid-row: 2;
    align-self: end;
    background-color: var(--navy);        
}

.banner-carousel__track {
    display: flex;
    transition: transform 0.3s ease-in-out;
    position: relative;   

    &:has(>.banner-carousel__slide:only-child) + .banner-carousel__controls,
    &:not(:has(.banner-carousel__slide)) + .banner-carousel__controls {
        display: none;
    }
}

.banner-carousel__slide {
    flex: 0 0 100%;
    width: 100%;
    position: relative;
    transition: opacity 0.3s;
    overflow: hidden; 
    background-color: var(--navy);
}

.banner-carousel__controls {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    padding: 8px 22px;
    background-color: var(--light-grey);
    position: relative;
    z-index: 3;
}

.banner-carousel__button {
    background: none;
    border: none;
    cursor: pointer;
    position: relative;
    z-index: 2;
    outline: none;
    height: 24px;
}

.banner-carousel__arrow {
    width: 10px;
    height: 16px;
    margin: 4px 0;
    fill: var(--navy);
}

.banner-carousel:has(.current-slide .alert-banner--purple) {
    .banner-carousel__arrow path {
        fill: var(--white);
    }
    .banner-carousel__dot {        
        border-color: var(--white);
    }
    .banner-carousel__dot[aria-selected="true"] {
        background-color: var(--white);
    }
}

.banner-carousel__pagination {
    display: flex;
    gap: 24px;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
}

.banner-carousel__dot {
    width: 12px;
    height: 12px;
    border: 1.5px solid var(--navy);
    border-radius: 50%;
    background-color: transparent;
    padding: 0;
    cursor: pointer;
}

.banner-carousel__dot[aria-selected="true"] {
    background-color: var(--navy);
}

.banner-carousel__dot:focus-visible {
    outline: 2px solid var(--navy);
    outline-offset: 2px;
}

.banner-content a:focus {
    outline: 2px solid var(--navy);
    outline-offset: 2px;
    position: relative;
    z-index: 2;
}

.banner-carousel__arrow--prev {
    transform: rotate(180deg);
}

.banner-carousel__arrow--next {
    transform: rotate(0deg);
}

/* Alert Banners */
.alert-banner {
    padding: 22px;
    z-index: 500;
}

.alert-banner.not_logged_in {
    margin-top: 0!important;
}

.alert-banner__header {
    display: grid;
    grid-template-columns: fit-content(30px) 1fr fit-content(60px);
    grid-template-areas: 
        "icon title close"
        "icon content content"
        "icon action action";   
    position: relative;
}

.alert-banner__icon-wrapper {
    grid-area: icon;  
    margin-right: 10px;  
}

.alert-banner__icon {
    width: 22px;
    height: 22px; 
}

.alert-banner__title {
    color: var(--navy);
    margin-bottom: 0;
    line-height: 26px;
    grid-area: title;
}

.alert-banner__title:empty + .alert-banner__content:has(p) {
    margin-top: 0;
}

.alert-banner__content:has(p) {
    color: var(--navy);
    margin-top: 6px;
    grid-area: content;
}

.alert-banner__close {
    padding-left: 30px;
    grid-area: close;
    align-self: start;
    justify-self: end;
}

.alert-banner__close-icon {
    width: 15px;
    height: 15px;
}

.alert-banner__actions {
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    align-items: flex-end;
    gap: 20px;
    grid-area: action;
    margin-top: 20px;
}

.alert-banner a:not(.btn),
.alert-banner a:not(.btn):visited {
    color: var(--navy);
}

.alert-banner a:not(.btn):hover {
    color: var(--dark-blue);
}

.alert-banner-carousel__controls::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 27, 63, 0.20);
    pointer-events: none;
}

.alert-banner-container .banner-carousel__slide {
    display: flex;
}

.alert-banner-container .banner-carousel__slide .alert-banner {
    flex-grow: 1;
}

#responseMessage .alert-banner__icon-wrapper::after {
    display: block;
    content: '';
    width: 22px;
    height: 22px;    
    background-size: cover;
    background-repeat: no-repeat;
}

#responseMessage.alert-banner--red .alert-banner__icon-wrapper::after {
    background-image: url('/assets/myairdrie/img/icons/white/alert-icon.svg');
}

#responseMessage.alert-banner--green .alert-banner__icon-wrapper::after {
    background-image: url('/assets/myairdrie/img/icons/navy/save-icon.svg');
}

/* Alert variants */
.alert-banner--red {
    background-color: var(--red);
}

.alert-banner--red .alert-banner__title,
.alert-banner--red .alert-banner__content,
.alert-banner--red a:not(.btn),
.alert-banner--red a:not(.btn):visited {
    color: var(--white);
}

.alert-banner--red a:not(.btn):hover {
    color: var(--light-grey);
}

.alert-banner--orange,
.alert-banner-container .banner-carousel:has(.current-slide .alert-banner--orange) .alert-banner-carousel__controls {
    background-color: var(--orange);
}

.alert-banner--green,
.alert-banner-container .banner-carousel:has(.current-slide .alert-banner--green) .alert-banner-carousel__controls {
    background-color: var(--green);
}

.alert-banner--purple,
.alert-banner-container .banner-carousel:has(.current-slide .alert-banner--purple) .alert-banner-carousel__controls {
    background-color: var(--accent-purple);
}

.alert-banner--yellow,
.alert-banner-container .banner-carousel:has(.current-slide .alert-banner--yellow) .alert-banner-carousel__controls {
    background-color: var(--yellow);
}

.alert-banner--purple .alert-banner__title, 
.alert-banner--purple .alert-banner__content,
.alert-banner--emergency .alert-banner__title,
.alert-banner--emergency .alert-banner__content,
.alert-banner--emergency a:not(.btn),
.alert-banner--emergency a:not(.btn):visited {
    color: var(--white);
}

.alert-banner--emergency a:not(.btn):hover {
    color: var(--light-grey);
}

.alert-banner.alert-banner--emergency {
    background-color: var(--red);
    padding: 0 var(--lr-padding);
}

.alert-banner--emergency .alert-banner__content {
    margin-top: 0;
    padding-left: 32px;
}

.expanding-section__control_container {
    display: grid;
    grid-template-rows: 1fr;
    grid-template-columns: 1fr;
    align-items: center;
    justify-content: center;
    margin-top: 8px;
}
.alert-banner--emergency .expanding-section__control {    
    width: 16px;
    height: 16px;   
    grid-column: 1;
    grid-row: 1;
}
.alert-banner--emergency .expanding-section__control::after  {
    display: none;
}

.alert-banner__control_icon {
    grid-column: 1;
    grid-row: 1;
}

.alert-banner--emergency .alert-banner__icon-wrapper {
    margin-top: 3px;
}

.alert-banner--emergency .expanding-section__header {
    padding: 20px 0;
}

.alert-banner--emergency >.expanding-section__header .expanding-section__control:checked ~ .alert-banner__control_icon.expand_icon {
    display: none;
}

/* Calendar */
.calendar-events-container {
    display: flex;
    flex-direction: column;
    gap: 20px;
    background-color: var(--white);    
}

.calendar-event {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 10px;
    align-items: start;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--light-grey2);

    &:has(.calendar-button) {
        grid-template-columns: auto 1fr 1fr;
    }
}

.calendar-date {
    background-color: var(--light-grey);
    padding: 8px 2px;
    width: 45px;
    text-align: center;
    font-family: 'urbane-rounded', sans-serif;
    font-size: 14px;
    font-weight: 500;
    line-height: 18px;
    color: var(--navy);
    border-radius: 2px;
    letter-spacing: 0.2px;
}

.calendar-date .month,
.calendar-date .day {
    display: block;
}

.calendar-date--range {
    min-width: 75px;
}

.calendar-content:not(:last-child) {
    margin-right: 10px;
}

.calendar-content h4 {
    margin-top: 2px;
    margin-bottom: 5px;
    line-height: 21px;
}

.calendar-content h4 a,
.calendar-event .calendar-content p {
    line-height: 21px;
    margin-bottom: 0;
}

.calendar-link {
    margin-top: 10px;
    display: inline-block;
}

.calendar-icons {
    display: flex;
    gap: 8px;
    align-items: center;
}

.calendar-icon {
    width: 40px;
    height: 40px;
}

.calendar-button {
    margin-left: auto;
}

.calendar-event:nth-last-child(1 of .calendar-event:not(.hide)) {
    border-bottom: none;
    padding-bottom: 0;
}

.action-links-container {
    display: flex;
    gap: 12px;
    justify-content: flex-end;
    margin-top: 12px;
}

.action-links-container--account {   
    display: grid;
    grid-template-columns: 1fr;  
    gap: 30px 10px;
}

.action-links-container--space-between {
    justify-content: space-between;
    padding-left: 0;
    padding-right: 0;
}

.expanding-section-container--service .action-links-container--account {
    margin: 0 var(--lr-margin);
}

.action-links-container--account .search-focus {
    grid-column: span 2;
    text-align: left;    
}

.view-more-display-count {
    font-style: italic;
}

.action-links-container--account p {
    font-style: italic;
    color: var(--black);
    margin-bottom: 0 !important;    
}

.dashboard-container {
    display: flex;
    flex-direction: column-reverse;
}

main:has(.maintenance_alert) .dashboard-container {
    display: none;
}

.dashboard-news-container:not(:has(div)) {
    display: none;
}

.dashboard-news-container .content_block.content_custom, .service-container .service-top-container .service-top-container__grid .content_block {
    margin: 0!important;
    padding: 0!important;
}

.dashboard-news-container .calendar-container {
    margin: var(--tb-margin) var(--lr-margin);
    border-radius: 2px;
    background-color: inherit; 
 }
 
.dashboard-news-container .calendar-container h2 {
    background-color: var(--navy);
    color: var(--white);
    padding: 22px;
    margin-bottom: 0;   
    border-radius: 2px 2px 0 0; 
}
 
.dashboard-news-container .calendar-events-container {
    padding: 22px;
    border-radius: 0 0 2px 2px ; 
}

.dashboard-news-container .calendar-container .action-links-container {
    background-color: var(--white);
    margin-top: 0;
    padding: 0 22px 22px;
}

.dashboard-news-container .calendar-container .action-links-container span:has(+button.hide) {
    display: none;
}

/* Service Cards */
.service-cards {
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
}

.service-card {
    padding: 22px;
    border-radius: 5px;
}

.service-card__grid {
    display: flex;
    justify-content: space-around;
    align-items: flex-start;
    gap: 30px;
}

.service-card__content {
    flex: 1;
}

.service-card__title {
    margin-bottom: 8px;
}

.service-card__text {
    margin-bottom: 0;
}

.service-card__icon {
    width: 40px;
    height: 40px;
    flex-shrink: 0;
}

.service-card__actions {
    display: flex;
    flex-direction: column;
    gap: 10px;
    align-items: flex-end;
    margin-top: 17px;
}

.cards-container .action-links-container {
    margin-top: 32px;
}

/* Page cards */
.page-card-wrapper {
    container-type: inline-size;
    container-name: page-card;
}

.page-card {
    background-color: var(--light-grey);
    padding: 22px;
    border-radius: 2px;
    display: grid;
    grid-template-columns: minmax(40px, max-content) 1fr;
    column-gap: 10px;
}

.page-card__icon {
    width: 40px;
    height: 40px;
}

.page-card__header {
    grid-column: 1 / -1;
    grid-row: 1;
}

.page-card__content-wrapper {
    grid-column: 2;
    grid-row: 1;
}

.page-card .page-card__content {
    margin-bottom: 0;
}

.page-card__title {
    margin-bottom: 8px;
}

.page-card__title span {
    font-weight: 400;
}

.page-card__actions {
    grid-column: 1 / -1;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
}

.page-card__actions .btn {
    margin-top: 17px;
}

.page-card__actions a:not(.btn) {
    margin-top: 22px;
}

/* Page card - submit styles */
.page-card__submit {
    grid-column: 1 / -1;
    grid-row: 2;
    display: grid;
    grid-template-columns: 1fr;
    margin-top: 20px;
    box-shadow: 3px 3px 6px 0px rgba(0, 47, 83, 0.25);
    border-radius: 3px;
    overflow: hidden;
    background-color: var(--white);
    height: min-content;
    align-self: center;
}

.page-card__submit--pin,
.page-card__submit--pin +.submit-error-message {
    grid-column: 2;
}

.page-card__input {
    padding: 12px 14px;
    border: 1px solid transparent;
    border-radius: 3px 0 0 3px;
    font-family: 'urbane-rounded', sans-serif;
    font-size: 14px;
    line-height: 24px;
    color: var(--navy);
    width: 100%;
    grid-column: 1;
    grid-row: 1;
}

.page-card__input:focus {
    border: 2px solid var(--green);
    outline: none;
}

.page-card__input::placeholder {
    color: var(--grey);
}

.page-card__submit-button {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 12px 16px;
    background-color: var(--green);
    border: none;
    color: var(--navy);
    font-family: 'urbane-rounded', sans-serif;
    font-size: 14px;
    font-weight: 500;
    line-height: 24px;
    cursor: pointer;
    transition: background-color 0.3s ease;
    grid-column: 2;
}

.page-card__submit-button:hover {
    background-color: #8EBD50;
}

/* Page card - submission error */
.page-card.has_error .page-card__input {
    border-color: var(--red);
    padding-left: 35px;
    background-image: url('/assets/myairdrie/img/icons/red/alert-icon.svg');
    background-repeat: no-repeat;
    background-position: 12px center;
    background-size: 16px;
}

.page-card.has_error .page-card__input::placeholder {
    color: var(--red);
}

.submit-error-message {
    grid-column: 1 / -1;
    position: relative;
    background-color: var(--red);
    color: var(--white);
    padding: 20px;
    margin-top: 25px;
    border-radius: 2px;
}

.submit-error-message::before {
    content: '';
    position: absolute;
    top: -8px;
    left: 20px;
    width: 16px;
    height: 16px;
    background-color: var(--red);
    transform: rotate(45deg);
}

.submit-error-message a,
.submit-error-message a:visited {
    color: var(--white);
}

.submit-error-message a:hover {
    color: var(--light-grey);
}

/* Visually hidden class */
.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: none;
}

/* Page card - chart styles */
.page-card__charts {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(106px, 1fr));
    gap: 20px;
    margin-top: 20px;

    & .page-card__chart {
        margin-top: 0;
    }
}

.page-card__chart {
    margin-top: 20px;
    border-radius: 2px;
    text-align: center;
    display: grid;
    grid-template-rows: min-content 1fr;
}

.chart-header {
    padding: 10px 16px;
    border-radius: 2px 2px 0 0;    
}

.chart-header h4 {
    font-family: 'urbane-rounded', sans-serif;
    font-size: 14px;
    font-style: normal;
    font-weight: 500;
    line-height: 18px;
    margin-bottom: 0;
    letter-spacing: 0.4px;
}

.chart-content {
    padding: 7px 16px 10px;
    background-color: var(--white);
    border-radius: 0 0 2px 2px;
    align-content: center;
}

.chart-content h5 {
    margin-bottom: 0;
    line-height: 18px;
}

/* Base expanding section styles */
.expanding-section-container,
.expanding-section {    
    break-inside: avoid;
}

.expanding-section--bordered {
    border-bottom: 1px solid var(--light-grey2);
}

.expanding-section--bordered:nth-child(1 of .expanding-section) {
    border-top: 1px solid var(--light-grey2);
}

.content_block.no-border-top .expanding-section--bordered {
    border-top: 0;
}

.expanding-section:has(+hr.section-divider) {
    margin-bottom: 0;
}

.expanding-section__header {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 16px 0 20px;
    border: none;
    text-align: left;    
}

.expanding-section:not(.expanding-section--service) .expanding-section__header:has(.expanding-section__control:checked) {
    padding-bottom: 11px;
}

.expanding-section__header-img {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    gap: 10px;
}

.expanding-section__header .expanding-section__title {
    margin-bottom: 0;
    padding-right: 30px;    
}

.expanding-section__header .expanding-section__title:has(+p) {
    margin-bottom: 8px;
}

.expanding-section__header .icon-circle {
    width: 42px;
    height: 42px;
}

.expanding-section__header .service-icon {
    width: 28px;
    height: 28px;
}

.expanding-section__title {
    display: flex;
    column-gap: 10px;
}

.content_block:not(.content_html) .expanding-section:not(.is-expanded) .expanding-section__title,
.content_block.content_html.collapsible .expanding-section .expanding-section__title {
    flex-grow: 1;
    cursor: pointer;
}

.expanding-section__control {
    width: 20px;
    height: 20px;
    appearance: none;
    cursor: pointer;
    position: relative;
    flex-shrink: 0;
}

.expanding-section__control::after {
    content: "";
    position: absolute;    
    width: 8px;
    height: 8px;
    border-width: 0 3.5px 3.5px 0;
    transform: rotate(45deg);
    transition: transform 0.2s ease-out;
    border-color: var(--black);
    border-style: solid;
    border-radius: 2px;
    top: 5px;
    left: 5px;
}

/* Prevent content blocks from expanding unless they are specifically set in the CMS */
.content_block.content_html:not(.collapsible) {
    & .expanding-section--bordered {
        border: none;
    }
    & .expanding-section {
        break-inside: initial;

        & .expanding-section__header {
            display: initial;                    
            padding: 0;    
            
            & h2, & .expanding-section__title {
                padding-right: 0;
                margin-bottom: 26px;
            }

            & h3 {
                padding-right: 0;
            }

            & .visually-hidden, .expanding-section__control {
                display: none;
            }
        }

        & .expanding-section__expansion {
            display: initial;
            padding: 0;
        }
    }
}

.expanding-section__control:checked::after {
    top: 10px;
    transform: rotate(225deg);
    transition: transform 0.2s ease-out;
}

.expanding-section__expansion {
    display: none;
    padding-bottom: 30px;
}

.expanding-section.is-expanded>.expanding-section__header {
    cursor: unset;
}

.expanding-section.is-expanded>.expanding-section__header .expanding-section__control {
    display: none;
}

.expanding-section.is-expanded>.expanding-section__expansion {
    display: block;
}

.expanding-section__content p:not(:last-child, :has(+hr)) {
    margin-bottom: 25px;
}

.expanding-section__actions {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    margin-top: 40px;
    gap: 40px;
}

.expanding-section__actions:not(:last-child) {
    margin-bottom: 40px;
}

.expanding-section__actions p {
    align-self: flex-start;
}

/* Animation states - works for both nested and non-nested sections */
.expanding-section__header:has(.expanding-section__control:checked) + .expanding-section__expansion {
    display: block;
    animation: expandContent 0.2s ease-out;
}

.expanding-section__header:has(.expanding-section__control:not(:checked)) + .expanding-section__expansion  {
    animation: collapseContent 0.2s ease-out;
}

/* Animation keyframes */
@keyframes expandContent {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes collapseContent {
    from {
        opacity: 1;
        transform: translateY(0);
    }

    to {
        opacity: 0;
        transform: translateY(-10px);
    }
}

/* Reduced motion */
@media (prefers-reduced-motion) {
    .expanding-section__header:has(.expanding-section__control:checked) + .expanding-section__expansion {        
        animation: none;
    }

    .expanding-section__control {
        transition: none;
    }
}

/* Expanding section - highlight card */
.expanding-section--highlight-card, .content_block.collapsible.light_blue .expanding-section {
    background-color: var(--light-blue);
    border-radius: 2px;
    padding: 0 22px;
    box-shadow: 1px 3px 6px rgba(0, 47, 83, 0.25);
}

.expanding-section--highlight-card:not(:last-child) {
    margin-bottom: 20px;
}

.expanding-section--highlight-card .info-items-container p {
    margin-bottom: 22px;
}

.expanding-section--highlight-card .info-items-container h4 {
    margin-bottom: 4px;
}

.expanding-section--highlight-card .pap .info-items-container p {
    margin-bottom: 8px;
}

.expanding-section--highlight-card .expanding-section__header {
    padding-bottom: 21px;
}

/* Expanding section - service page */
.expanding-section-container--service:has(.expanding-strip) {
    margin: 0 calc(var(--lr-margin) * -1);
}

.expanding-strip {
    margin-bottom: 25px;
    box-shadow: 1px 3px 6px 0px rgba(0, 47, 83, 0.25);
    border-top-style: solid;
    border-top-width: 10px;

    &:has(>.expanding-section--service >.expanding-section__header .expanding-section__control:checked),
    &:has(>.expanding-section--service.is-expanded) {
        border-bottom-style: solid;
        border-bottom-width: 5px;
    }

    &:has(.tax-assessment-bg) {
        border-color: var(--accent-turquoise);
    }

    &:has(.waste-recycling-bg) {
        border-color: var(--accent-mid-green);
    }

    &:has(.utilities-water-bg) {
        border-color: var(--accent-light-blue);
    }

    &:has(.business-owners-bg) {
        border-color: var(--accent-light-yellow);
    }

    &:has(.animal-licensing-bg) {
        border-color: var(--accent-brown);
    }

    &:has(.permits-construction-bg) {
        border-color: var(--accent-gold);
    }

    &:has(.programs-classes-bg) {
        border-color: #B2A0CC;
    }

    &:has(.rentals-bookings-bg) {
        border-color: #8FC8A5;
    }

    &:has(.closures-repairs-bg) {
        border-color: #E99D60;
    }

    &:has(.online-payments-bg) {
        border-color: #D0A7AB;
    }

    &:has(.airdrie-transit-bg) {
        border-color: #DFA7E9;
    }
}

.expanding-section--service>.expanding-section__header {
    padding: 13px 22px 16px;
    display: grid;
    grid-template-columns: 1fr auto;    
    align-items: start;
    border: none;
    text-align: left;
    grid-template-areas: 
        "header control"
        "content content"
        "optional optional";
}

.expanding-section--service>.expanding-section__header .expanding-section__control {
    grid-area: control;
    justify-self: end;
}

.expanding-section--service>.expanding-section__header .expanding-section__title {
    grid-area: header;
}

.expanding-section--service .expanding-section__header-content {
    grid-area: content;
    margin-top: 3px;

    & p:not(:last-child) {
        margin-bottom: 4px;
    }

    &:not(:has(+.expanding-section__header-optional)) {
        grid-column: span 2;
    }
}

.expanding-section--service .expanding-section__header-optional {
    grid-area: optional;
    margin-top: 11px;
    display: flex;
    flex-direction: column;
    gap: 2px; 
}

.expanding-section--service .expanding-section__header-optional h5 {
    margin-bottom: 0;
}

.expanding-section--service>.expanding-section__expansion {
    padding: 22px 22px 29px;
}

.expanding-section-links-container {
    display: flex;
    flex-direction: row;
    gap: 20px; 
}

.expanding-section__links:has(a, .btn-link) {
    margin-top: 22px;
    display: grid;
    grid-template-rows: 1fr;
    gap: 18px var(--gutter);
    justify-items: start;
    flex-grow: 1;

    &:not(:last-child, :has(+hr)) {
        margin-bottom: var(--tb-margin);
    }
}

.expanding-section__button {
    margin-top: 30px;
}

/* Highlight card (not expandable)*/
.highlight-card {
    background-color: var(--light-blue);
    padding: 22px var(--lr-padding);
    margin-top: var(--tb-margin);
    border-radius: 2px;    
}

.highlight-card:nth-child(1 of .highlight-card) {
    margin-top: 0;
}

/* Tables */
table {
    width: 100%;
    border-collapse: collapse;
}

tr {
    border: 1px solid var(--light-grey2);
}

td, th {
    padding: 15px 22px;
    font-family: 'arboria', sans-serif;
    font-size: 16px;
    line-height: 24px;
    color: var(--black);
    text-align: left;
    vertical-align: top;    
}

td span,
.document-setting-row span {
    font-weight: 700;
}

table:not(:first-child),
.collapsing-table-container:not(:first-child) {
    margin-top: 30px;
}

.transaction,
.document-setting,
.collapsing-table {
    width: 100%;
    border-collapse: collapse;    
    border: 1px solid var(--light-grey2);
}

.transaction-row {
    display: grid;
    grid-template-columns: 130px 1fr;
    grid-template-rows: repeat(4, auto);
    column-gap: 10px;
    padding: 15px 22px;
    border-bottom: 1px solid var(--light-grey2);
    position: relative;
    font-family: 'arboria', sans-serif;
    font-size: 16px;
    line-height: 24px;
    color: var(--black);
}

.transaction-row:last-child,
.transaction-row:has(+ .transaction-row.hide),
.document-setting-row:last-child,
.collapsing-row:last-child,
.collapsing-row:has(+ .collapsing-row.hide) {
    border-bottom: none;
}

.document-setting-row,
.collapsing-row {
    display: grid;
    grid-template-columns: 2fr 1fr;
    padding: 15px 22px;
    border-bottom: 1px solid var(--light-grey2);
    position: relative;
    font-size: 16px;
    line-height: 24px;
    gap: 8px 20px;
}

.document-setting-full {
    grid-column: span 2;
}

.document-setting__service {
    margin-bottom: 2px;
}

.document-setting__list {
    display: grid;
    grid-template-columns: 2fr 1fr;
    grid-column: span 2;
    gap: 20px;
}

.document-setting .document-setting__list ul {
    margin-bottom: 0;
}

tr:nth-child(odd),
.transaction-row:nth-child(odd),
.document-setting-row:nth-child(odd),
.collapsing-row:nth-child(odd) {
    background-color: var(--light-grey);
}

tr:nth-child(even),
.transaction-row:nth-child(even),
.document-setting-row:nth-child(even),
.collapsing-row:nth-child(even) {
    background-color: var(--white);
}

.transaction-date {
    grid-row: 1 / -1;
}

.transaction-action {
    display: flex;
    flex-wrap: wrap;
    align-items: start;
    column-gap: var(--gutter);
}

/* Manage account */
.user-banner {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 20px;
    margin: calc(var(--tb-margin) * -1) calc(var(--lr-margin) * -1) 0;
    padding: 22px var(--lr-padding);
    align-items: center;
}

.user-banner__info h3,
.user-banner__email h5 {
    margin-bottom: 0;
}

.user-banner .user-banner__email p {
    margin-bottom: 5px;
    overflow-wrap: anywhere;
}

.manage-account-actions {
    border-radius: 2px;
    box-shadow: 3px 3px 6px 0px rgba(0, 47, 83, 0.25);
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    column-gap: 30px;
    padding: 22px 15px;
    justify-items: center;    
}

.manage-account-action {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;    
    gap: 11px;
    width: 100%;
}

.user-banner .manage-account-action {
    gap: 5px;
}

.manage-account-action__icon {
    width: 20px;
    height: 20px;
}

.manage-account-action a,
.manage-account-action .btn-link {
    line-height: 18px;
    text-align: center;
}

#addShortcutContainer {
    display: flex;
    align-items: end;
}

.edit-info {
    display: flex;
    gap: 35px;   
}

.edit-info h4 {
    margin-bottom: 0;
}

.two-factor-key {
    overflow-wrap: break-word;
}

/* Account members */
.account-member {
    border-top: 1px solid var(--white);
    margin-top: var(--tb-padding);
    padding-top: var(--tb-padding);
}

.expanding-section .expanding-section__content .account-member p {
    margin-bottom: 8px;
}

/* Draggable favourites */
.favourites-sort-container {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.favourites-sort__item {
    display: grid;
    grid-template-columns: 40px 1fr auto;
    align-items: center;
    border-radius: 2px;
    padding-right: 22px;
    box-shadow: 3px 3px 6px 0px rgba(0, 47, 83, 0.25);
}

.favourites-sort__handle {
    width: 100%;
    background-color: rgba(0, 0, 0, 0.1);
    border-radius: 2px 0 0 2px;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: center;
    align-self: stretch;
    cursor: grab;
}

.ellipsis {   
    width: 4px;
    height: 16px;
}

.favourites-sort__service {
    padding: 18px 18px 18px 15px;
    margin-bottom: 0;
}

/* Modal Styles */
body.show_modal {
    overflow: hidden;
}

.modal {
    position: fixed;
    top: 20% !important;
    left: 50% !important;
    transform: translate(-50%, -20%) scale(1);
    background: var(--white);
    border-radius: 3px;
    max-width: 90%;
    max-height: 90%;
    transition: all 0.3s ease;
    z-index: 1001;
    overflow-y: auto;
}

.modal__header {
    background-color: var(--white);
    padding: 40px;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 20px;
    border-radius: 3px 3px 0 0;
}

.modal__title {    
    font-family: 'urbane-rounded', sans-serif;
    font-size: 22px;
    font-weight: 300;
    line-height: 32px
}

.modal-close-button::after {
    content: url('/assets/myairdrie/img/icons/navy/close-popup-icon.svg');
    width: 23px;
    height: 23px;
}

.modal__content {
    display: none;
    background-color: var(--light-blue);
    padding: 40px;
    border-radius: 0 0 3px 3px;
}

.modal__actions {
    margin-top: 40px;
    display: flex;
    flex-direction: column;
    gap: 40px;
    align-items: flex-end;
}

.recreation-modal h4 {
    margin-bottom: 6px;
}

/* Receipt modal */
.receipt-modal {    
    background-color: var(--med-blue);

    & .modal__header {    
        padding-bottom: 32px;
        background-color: var(--med-blue);    
        color: var(--white);    
    }

    & .modal__content {
        background-color: var(--med-blue);    
        padding: 0;
    }

    & .receipt__header {
        padding: 25px 0 33px;
        margin: 0 40px;
        border-top: 1px solid var(--white); 
        background-color: var(--med-blue);
        color: var(--white);       

        & h1 {
            display: none;
        }

        & h5 {
            margin-bottom: 5px;
        }

        & .header-image {        
            margin-top: 20px;
        }

        & .airdrie-logo {
            width: 109px;
            height: 33px;
        }
    }

    & .receipt__body {
        background-color: var(--white);
        padding: 40px;
    }
}

.receipt__body {
    & .receipt__content {
        margin-bottom: 50px;
    }

    & .flex-row {
        display: flex;
        flex-direction: column;        
    }

    & .payment-item {
        display: flex;
        gap: 20px;
        justify-content: space-between;        

        &.payment-item--total {
            font-weight: 700;
        }
    }

    & :nth-last-child(1 of .payment-breakdown) {
        margin-bottom: 25px;
    }

    & .payment-type {
        margin-top: 25px;
    }

    & .payment-actions {
        margin-top: 25px;
        display: flex;
        flex-direction: column;
        row-gap: 25px;
        justify-self: end;
        text-align: right;
    }
}

.receipt__message {
    text-align: right;
}

.content_block.content_form:has(#paymentReceiptContainer) {
    margin-top: 0 !important;
}

#paymentReceiptContainer .alert-banner {
    margin: 0 calc(var(--lr-margin) * -1) var(--tb-margin);
}

/* Overriding jquery UI modal overlay style */
.ui-widget-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.8);
    backdrop-filter: blur(5px);
    transition: opacity 0.3s ease;
    z-index: 1000;
}

/* Settings */
.settings {
    padding: 22px 15px 25px;
}

.settings--communication {
    border-radius: 2px;
}

.settings--communication h4 {
    display: inline-block;
    margin-bottom: 0;
}

.settings--communication .settings__summary {
    display: grid;
    grid-template-columns: 1fr;
    row-gap: 19px;

    & .myairdrie_email {
        overflow-wrap: anywhere;
    }
}

/* Alerts and reminders */
.alerts-reminders {
    padding: 30px 0;
}

.alerts-reminders__action {
    margin-top: 40px;
    display: flex;
    justify-content: flex-end;
}

.bordered-sections:last-child {
    border-bottom: 1px solid var(--light-grey2);
}

.bordered-section {
    display: grid;
    grid-template-columns: min-content auto;
    column-gap: 10px;
    border-top: 1px solid var(--light-grey2);
    padding: 25px 0;
    break-inside: avoid;

    & .icon-circle {
        width: 37px;
        height: 37px;
    }

    & .service-icon {
        width: 25px;
        height: 25px;
    }

    .bordered-section__header {
        display: flex;
        justify-content: space-between;

        & h3 {
            margin-bottom: 0;
        }
    }
}

.bordered-section form {
    grid-column: 1 / -1;
}

/* Maintenance and 404 pages */
.message-block {
    padding: 40px var(--lr-padding);
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.message-block:last-child {
    padding-bottom: 0;
}

.message-block h2 {
    margin-bottom: 30px;
}

.message-block__icon {
    height: 60px;
    width: auto;
    margin-bottom: 30px;
}

.message-block .recent-links-container {
    text-align: left;
    width: 100%;
}

.buttons-container {
    column-gap: 20px;
    display: flex;
    justify-content: flex-end;
}

.buttons-container--column {
    row-gap: 30px;
    flex-direction: column;
    align-items: flex-end;
}

.pap .buttons-container--column {
    row-gap: 12px;
    margin-top: 24px;
}

.message-banner {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 10px;
    padding: 40px var(--lr-padding);

    &.maintenance_alert {
        ul:not(:last-child), p:not(:last-child) {
            margin-bottom: 1em;
        }
    }
}

.message-banner__icon {
    width: 58px;
    height: auto;
    flex-shrink: 0;
}

/* Search */
#searchResults {
    margin-top: var(--tb-margin);
}

.search-result-item {
    padding: 25px 0;
    border-bottom: 1px solid var(--light-grey2);
}
        
.search-result-item:first-child {
    border-top: 1px solid var(--light-grey2);
}

.search-result-item p {
    margin-top: 15px;
}

/* Assessement report */
#assessmentReportContainer {
    display: grid;    
    background-color: var(--light-blue);
    margin-bottom: 30px;    
    padding: 20px;
    border-radius: 2px;

    & table {
        margin-top: 0;
    }

    & td {
        width: 50%;
    }

    & td:nth-child(odd) {
        padding: 15px 10px 15px 20px;
    }

    & td:nth-child(even) {
        padding: 15px 20px 15px 10px;
    }
}

#assessmentReport.loading {
    min-height: 500px;
}

#assessmentReportDetails {
    margin-top: var(--tb-margin);

    &.loading {
        min-height: 900px;
    }

    & table:not(:last-child) {
        margin-bottom: calc(var(--tb-margin) / 2);
    }
}

#assessmentReportDetails:not(.loading):not(:has(table)) {
    display: none !important;
}

#assessmentMapContainer {
    margin-top: var(--tb-margin);

    & h5 {
        margin-bottom: 0;
    }
}

#assessmentMap {
    border: 1px solid var(--navy);
    height: 209px;
    width: 100%;
    margin-bottom: 15px;
}

/* reCAPTCHA */
.grecaptcha-badge {
    visibility: hidden;
}

/* Mobile - up to 389px */
@media (width < 390px) {
    .site-header__logo {
        width: 120px;        
    }

    .transaction-row {
        grid-template-columns: 100px 1fr;
    }
}

/* Mobile - up to 414px */
@media (width < 414px) {
    .page-card__submit-button .responsive-text {
        position: absolute;
        width: 1px;
        height: 1px;
        padding: 0;
        margin: -1px;
        overflow: hidden;
        clip: rect(0, 0, 0, 0);
        white-space: nowrap;
        border: none;
    }
}

/* Mobile - up to 767px */
@media (width < 768px) {
    .site-header__link, .site-header__menu {
        flex-direction: column;
        align-items: center;
        text-align: center;
        gap: 4px;
        line-height: 20px;
    }

    .dashboard-menu__link {
        max-width: 100px;
    }

    .dashboard-menu__link p {
        display: none;
    }

    .menu-open .dashboard-menu__link--help {
        display: flex;
        flex-direction: row;
        justify-content: flex-start;
        position: fixed;
        bottom: 0;
        left: 0;
        width: 100%;
        max-width: unset;
        background-color: var(--dark-blue);
        border-bottom: 15px solid var(--navy);
        padding: var(--tb-padding) var(--lr-padding);
    }

    .menu-open .nav__section--secondary {
       padding-bottom: 130px;
    }

    .btn.service-title__button {       
        border-radius: 40px 0 0 40px;
    }

    .manage-account-action {
        max-width: 90px;
    }

    .transaction-desc {
        grid-column: 2;
    }

    .transaction-title {
        margin-bottom: 8px;
    }

    .transaction-amount,
    .transaction-action {
        grid-column: 2;    
        margin-top: 8px;
    }

    .transaction-date +.transaction-amount {
        margin-top: 0;
    }

    .collapsing-column {
        grid-column: 1;
        grid-row: 2;

        & +div {
            grid-row: span 2;
        }
    }

    #addShortcutContainer {
        flex-wrap: wrap;
        justify-content: center;
        
        & .info_faq {
            margin-top: 2px;
        }

        & .info_faq::after {
            margin-left: 0;
        }
    }
}

/* Tablet - 768px up to 1280px */
@media (width >= 768px) {
    :root {
        --lr-padding: 30px;
        --lr-margin: 30px;
        --gutter: 30px;
    }

    h1 {
        font-size: 24px;
        line-height: 34px;
        margin-bottom: 16px;
    }

    hr {
        margin-top: 30px;
        margin-bottom: 30px;
    }

    .responsive-column-container,
    .responsive-list {
        columns: 2;
        column-gap: var(--gutter);
    }

    .responsive-list li,
    .responsive-column-container>div {
        break-inside: avoid;
    }
    
    .site-header__left {
        padding: 25px 80px 25px 30px;
    }

    .site-header__right {
        padding-left: 20px;        
    }

    .site-header__actions,
    .dashboard-menu__actions {
        gap: 40px;
    }

    .site-footer__logo {
        width: 150px;
    }

    .wizard-header {
        flex-direction: row;
    }

    .wizard-header:has(.wizard-header__progress) {
        margin-bottom: 30px;
    }
    
    .wizard-header__progress {
        width: fit-content;
        border-top-right-radius: 30px;
        align-self: flex-end;
    }

    .wizard-header__content {
        position: relative;
        z-index: 1;
        padding: 20px 40px 0 30px;
        display: flex;
        align-items: center;
        gap: 40px;
    }

    .wizard-header__steps {
        gap: 5px;
    }   
    
    .wizard-steps__items {
        grid-template-columns: repeat(4, 1fr);
        padding: 30px 80px;
        gap: 35px;       
    }

    .wizard-steps__item:not(:last-child) {
        padding-right: 35px;
        border-right: 1px solid var(--white);
    }
    
    .wizard-steps__item h4 {
        margin-bottom: 0;
    }
    
    .wizard-steps__item:nth-child(-n+2) {
        border-bottom: none;
    }

    .wizard-steps__item:nth-child(even) {
        padding-left: 0;   
    }

    .wizard-steps__item:nth-child(n+3) {
        padding-top: 0;
    }

    .wizard-overview-container {
        padding: 0 80px;
    }

    .wizard-overview-container hr:nth-of-type(2) {
        display: none;
    }

    .wizard-overview__items {
        margin: 0 -80px;
        padding: var(--tb-padding) 80px;
    }

    .dashboard-container {
        display: grid;
        grid-auto-columns: minmax(0, 1fr);
        grid-auto-flow: column;
        height: 100%;
    }

    .dashboard-news-container {
        padding: 40px var(--lr-padding) 50px;
        margin-bottom: -50px;
        gap: 40px;
    }
    
    .dashboard-menu__link {
        flex-direction: row;    
    }

    .nav__section--secondary ul {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        column-gap: 30px;
    }

    .services-container .service-cards {
        display: block;
        column-count: 2;
        column-gap: 30px;        
    }

    .services-container .service-card {
        margin-bottom: 20px;
        break-inside: avoid;
    }

    .service-top-container__grid {
        grid-template-columns: 1fr 1fr;
    }

    .service-title__icon-wrapper {
        padding: 19px 0 19px 30px;
    }

    .service-title__icon-wrapper::after {
        right: -30px;
    }

    .service-title__heading {
        margin-left: 30px;
    }

    .service-title__action {
        margin-left: auto;
        padding-right: var(--lr-padding);
    }   

    .service-title__button--edit {
        width: max-content;
    }

    .service-title__button--edit a::after {
        content: ' favourites';
    }

    .quick-links-container {
        columns: 4;
    }

    .w-50 {
        width: 50%!important;
    }


    @container banner (width < 768px) {
        .banner-container {
            border-bottom-left-radius: 2px;
            border-bottom-right-radius: 2px;
        }       

        .banner-container,
        .banner-img {
            border-top-left-radius: 2px;
            border-top-right-radius: 2px;
        }       
    }

    @container banner (width >= 768px) {
        .banner-container {
            border-radius: 0;
            display: grid;
            grid-template-columns: 1fr 30%;
        }
            
        .banner-img {
            border-radius: 0;
        }
    
    
        .banner-content h4 {
            margin: 0;
            display: flex;
            flex: 1;
            flex-direction: column;
            height: 100%;
        }
    
        .banner-content span {
            display: block;
        }
    
        .banner-content a {
            align-self: flex-end;
            margin-top: auto;
            text-align: right;
        }
    }

    @container banner-carousel (width < 768px) {
        .banner-carousel .banner-container {
            border-bottom-left-radius: 0;
            border-bottom-right-radius: 0;
        }

        .banner-carousel .banner-carousel__controls {
            border-bottom-left-radius: 2px;
            border-bottom-right-radius: 2px;
        }
    }

    @container banner-carousel (width >= 768px) {
        .banner-carousel .banner-container {            
            grid-template-columns: 1fr 30%;
        }
        .banner-carousel .banner-container .banner-image {
            padding-bottom: 0;
        }

        .banner-carousel .banner-container .banner-content {
            grid-row: 1;
            grid-column: 2;
            align-self: auto;
            h4 {
                display: flex;                
                flex-direction: column;
                justify-content: space-between;
                height: 100%;
                a {
                    align-self: flex-end;
                    margin-top: 10px;
                    text-align: right;
                }
            }
        }

        .banner-carousel .banner-carousel__controls {
            border-radius: 0;
        }
    }

    .alert-banner {
        padding: 22px 30px;
    }

    .dashboard-news-container .calendar-container {
        margin: 0;
    }

    @container page-card (width >= 708px) {
        .page-card--search {
            grid-template-columns: auto 1fr 1fr;
            gap: 10px;
        }
    
        .page-card--search .page-card__header{
            grid-column: 1;
        }
    
        .page-card--search .page-card__content-wrapper {
            padding-right: 20px;
        }
    
        .page-card--search .page-card__submit {
            margin-top: 0;
            grid-row: 1;
            grid-column: 3;
        }
    }
    
    .expanding-section--service>.expanding-section__expansion>.expanding-section__content .page-card {
        width: 50%;
    }

    .expanding-section--service>.expanding-section__header {        
        grid-template-columns: 1.1fr 1fr auto;
        grid-template-areas: 
            "header header control"
            "content optional control";        
        row-gap: 3px;
    }

    .expanding-section--service .expanding-section__header-content,
    .expanding-section--service .expanding-section__header-optional {
        margin-top: 0;
        margin-right: 30px;
    }

    .expanding-section__links:has(a, .btn-link) {
        grid-template-columns: 1fr 1fr;
    }

    .transaction-row {
        padding: 15px 22px;
        column-gap: 20px;
    }

    .transaction-history .transaction-row {
        grid-template-columns: repeat(3, 1fr);
    }

    .transaction-history:has(.transaction-action) .transaction-row {
        grid-template-columns: repeat(4, 1fr);

        & .transaction-amount:not(:has(+ .transaction-action)) {
            grid-column: span 2;
        }
    }

    .transaction_history_container:not(:has(.transaction-history)) + .expanding-section__links {
        display: none;
    }

    .upcoming-payment .transaction-row {
        grid-template-columns: repeat(4, 1fr);
    }

    .transaction-row:has(div:nth-child(2):last-child) div:nth-child(2) {
        grid-column: 2 / -1;
    }

    .transaction-row:has(div:nth-child(3):last-child) div:nth-child(3) {
        grid-column: 3 / -1;
    }

    .transaction-title {
        grid-row: 1 / -1;
    }

    .transaction-amount {
        grid-column: 3;
        margin-top: 0;
        text-align: left;
    }
    
    .transaction-action {
        grid-column: 4;
        grid-row: 1;
        margin-top: 0;
        text-align: left;
    }

    .collapsing-row {
        grid-template-columns: repeat(3, 1fr);
    }

    .user-banner .manage-account-action {
        flex-direction: row;
    }

    .user-banner__email {
        display: grid;
        grid-template-columns: 1fr 1.5fr;
        gap: 30px;
    }

    .user-banner .user-banner__email p {
        margin-bottom: 0;
    }

    .manage-account-actions {
        padding: 30px;
    }

    .manage-account-actions .manage-account-action:not(:last-child) {
        padding-right: var(--lr-padding);
        border-right: 1px solid var(--white);
    }

    .bordered-sections:first-child {
        border-bottom: 1px solid var(--light-grey2);
    }

    .modal__title {       
        font-size: 24px;
        line-height: 34px;
    }

    .receipt-modal .modal__header {    
        padding-bottom: 37px;
    }

    .receipt-modal .receipt__header {
        padding: 30px 0 40px;
        display: flex;
        flex-direction: row;
        justify-content: space-between;

        & .header-image {
            margin-top: 0;
            margin-right: 60px;
        }
    }

    .settings--communication .settings__summary {
        grid-template-columns: 1fr 1fr;
        grid-template-rows: 1fr 1fr;
        grid-auto-flow: column; 
        column-gap: 80px;
    }

    .message-block {
        padding: 40px 80px;       
    }

    .message-block__icon {
        height: 90px;
    }

    .message-banner {
        padding: 40px 80px;
        gap: 30px;
    }

    .buttons-container {
        column-gap: 30px;
    }

    .search-result-item {
        padding: 30px 0;
    }

    #assessmentReportContainer {        
        grid-template-columns: 1fr 1fr;
        grid-template-rows: auto 1fr;
        column-gap: 40px;
        padding: 22px;

        & td:nth-child(odd) {
            padding-left: 22px;
        }
    
        & td:nth-child(even) {
            padding-right: 22px;
        }  
    }

    #assessmentReportDetails {
        grid-row: span 2;
        margin-top: 0;
    }

    #assessmentReportDetails:not(:has(table)) + #assessmentMapContainer {
        margin-top: 0;
    }
    
    #assessmentMap {
        height: 289px;
    }
}

/* Mobile and tablet- up to 1280px */
@media (width < 1281px) {
    .menu-open .dashboard-menu,
    .global-container:has(.dashboard-container) .dashboard-menu {
        display: initial;
    }

    .menu-open .global-container {
        height: 100vh;
    }

    .menu-open .alert-banner-container,
    .menu-open main,
    .menu-open footer {
        display: none;
    }

    .menu-open .nav__section--secondary {
        border-bottom: 15px solid var(--navy);
    }

    .nav__section--secondary li a {
        letter-spacing: 0.4px;
        text-underline-offset: 17%;
    }

    .icon-container {
        font-weight: 300;
        letter-spacing: 0.7px;
    }

    .wizard-steps__items {
        margin: 0 calc(var(--lr-margin) * -1);
    }

    .service-title__button .btn__img {
        display: none;
    }

    .service-top-container >.banner-carousel,
    .service-top-container >.banner-wrapper {
        margin-top: 22px;
    }

    .expanding-section:has(#addCommunity) {
        margin: 0 var(--lr-margin);
    }
}

/* Desktop - 1281px up to 2559px */
@media (width >= 1281px) {
    :root {
        --tb-padding: 40px;
        --lr-padding: 50px;
        --tb-margin: 50px;
        --lr-margin: 50px;
        --gutter: 50px;
    }

    body {
        font-size: 17px;
        line-height: 26px;
    }

    h1 {
        font-size: 32px;
        line-height: 42px;
        margin-bottom: 22px;
    }

    h2, .expanding-section__title {
        font-size: 24px;
        line-height: 30px;
        margin-bottom: 13px;
    }

    h3 {
        font-size: 20px;
        line-height: 28px;
        margin-bottom: 11px;
    }

    .content_block.collapsible .expanding-section__header .expanding-section__title,
    .expanding-section--highlight-card .expanding-section__title,
    .content_custom .expanding-section--bordered .expanding-section__title {
        font-size: 20px;
        line-height: 28px;
    }

    h4, .h4 {
        font-size: 17px;
        line-height: 26px;
        margin-bottom: 24px;
    }

    h5 {
        font-size: 15px;
        line-height: 25px;
        margin-bottom: 23px;
    }

    h6 {
        font-size: 14px;
        line-height: 24px;
        margin-bottom: 22px;
    }

    ol:not(:last-child, :has(+hr)),
    ul:not(:last-child, :has(+hr)) {
        margin-bottom: 54px;
    }

    li {
        margin-bottom: 16px;
    }

    ul.subsection-list {
        margin-bottom: 30px;
    }

    a,
    .btn-link {
        font-size: 15px;
        line-height: 26px;
    }

    .link-icon-container {
        gap: 10px;
    }

    .link-icon {
        width: 17px;
        height: 17px;
        top: 5px;
    }

    .settings--communication,
    .alerts-reminders {
        & .link-icon-container {
            gap: 12px;
        }

        & .link-icon {
            top: 3px;
            width: 24px;
            height: unset;
        }
    }

    ol a,
    ul a {
        letter-spacing: 0.2px;
    }

    small a,
    small .btn-link {
        font-size: 13px;
    }

    hr,
    hr.section-divider {
        height: 2px;
        margin-top: 40px;
        margin-bottom: 40px;
    }

    .border-top {
        border-top-width: 2px;
        margin-top: 40px;
        padding-top: 40px;
    }
    
    .border-bottom {
        border-bottom-width: 2px;
        margin-bottom: 40px;
        padding-bottom: 40px;
    }
    
    .responsive-list.utility-bills-list {
        columns: 3;
    }

    .recent-links-container .responsive-list {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
    }

    .site-footer {
        padding: var(--tb-padding) var(--lr-padding);
        margin-top: 70px;
    }

    .site-footer__logo {
        width: 196px;
    }

    .site-footer__links {
        gap: 26px;
    }

    .site-footer__link {
        font-size: 15px;
        line-height: 22px;
    }

    .breadcrumb-container +.content_block {
        margin-top: 40px !important;
    }

    .content_block p,
    .modal__content p {
        margin-bottom: 24px;
    }

    .expanding-section .expanding-section__content .account-member p {
        margin-bottom: 10px;
    }

    .content_block p:has(+ *:not(p, hr, ul, ol)),
    .modal__content p:has(+ *:not(p, hr, ul, ol)) {
        margin-bottom: 54px;
    }

    .content_block p:has(+ div),
    .modal__content p:has(+ div) {
        margin-bottom: 30px;
    }

    .global-container:has(nav div) {
        display: grid;
        grid-template-columns: 1fr 5fr;
        grid-template-rows: min-content min-content 1fr min-content;
        grid-template-areas: 
            "header header"
            "nav alert"
            "nav main"
            "nav footer";
    }

    .center-container {
        width: 1060px;
        margin: 0 auto;
    }

    header {
        grid-area: header;
    }

    nav:has(div) {
        grid-area: nav;
        display: flex;
        flex-direction: column;
        background-color: var(--dark-blue);
        padding: 50px;
        gap: 40px;
        grid-row: 2 / -1;
    }

    main {
        grid-area: main;
    }

    footer {
        grid-area: footer;
    }

    .site-header__container {
        grid-template-columns: 1fr auto auto;
        min-height: 100px;
    }

    .site-header__title {
        display: block;
    }

    .site-header__nav {
        display: flex;
        align-items: center;
        gap: 40px;
        background-color: var(--med-blue);
        position: relative;
        z-index: 500;
        padding: 0 20px;
    }

    .site-header__left {
        gap: 20px;
        padding: 29px 80px 29px 50px;
    }

    .site-header__logo {
        width: 188px;
    }

    .site-header__icon {
        width: 24px;
        height: 24px;
    }

    .site-header__link {
        font-size: 15px;
        font-weight: 300;
    }

    .site-header__menu {
        display: none;
    }

    .nav__section {
        flex-direction: column;
        padding: 0;
        border-bottom: 2px solid rgba(255, 255, 255, 0.20);
    }

    .nav__section--secondary {
        background-color: inherit;
        border-bottom: none;    
    }

    .nav__section--secondary ul {
        display: block;
    }

    .nav__section--secondary li {
        margin-bottom: 24px;
    }

    .nav__section a,
    .nav__section a:visited,
    .nav__section a:active,
    .nav__section a:focus {
        color: var(--white);
        text-decoration: none;
    }

    .nav__section a:hover {
        color: var(--light-blue);
    }

    .nav__section .icon-circle {
        width: 40px;
        height: 40px;
        flex: 0 0 40px;
    }

    .nav__section .service-icon {
        width: 24px;
        height: 24px;
    }

    .nav__section .icons-container {
        flex-direction: column;
        padding-bottom: 40px;
    }

    .nav__section .icon-container {
        flex-direction: row;
        max-width: unset;
        text-align: left;
        font-size: 15px;
        line-height: 24px;
        letter-spacing: 0.7px;
        font-weight: 300;
        gap: 20px;
    }

    .nav__link {
        font-size: 15px;
        line-height: 24px;
        letter-spacing: 0.7px;
        font-weight: 300;
    }

    .site-header__link.site-header__link--active,
    .nav__section .icon-container.icon-container--active,
    .nav__link.nav__link--active {
        text-decoration: underline;
        text-decoration-color: var(--white);
        text-underline-offset: 24%;
        text-decoration-skip-ink: auto;
        font-weight: 500;
    }
    
    .breadcrumb-container {
        margin-top: 21px;
    }

    .wizard-header:has(.wizard-header__progress) {
        margin-bottom: 40px;
    }

    .wizard-header__logo {
        margin-left: 50px;
        margin-right: calc((100vw - 1060px)/2);
        width: 220px;
    }

    .myairdrie-header__logo {
        width: 220px;
    }

    .wizard-header__content {
        padding-left: calc((100vw - 1060px)/2);
        padding-right: 70px;
        gap: 60px;
    }

    .wizard-header__step-icon {
        width: 32px;
        height: 32px;
    }

    .wizard-overview-container {
        padding: 0;
    }

    .wizard-overview__header {
        gap: 15px;
    }

    .wizard-overview__items {        
        margin: 0;
    }

    .wizard-steps__items,
    .wizard-overview__items {
        padding: 40px 35px;
        border-radius: 5px;
    }

    .wizard-steps__item:not(:last-child) {
        border-right: 2px solid var(--white);
    }

    .wizard-steps__icon {
        height: 35px;
    }

    .wizard-overview__icon {
        height: 36px;
    }

    .wizard-actions {
        gap: 50px;
        padding: 60px var(--lr-padding) 0;
    }

    .wizard-title-container {
        height: 84px;
        border-top: 15px solid #93B433;
    }  

    .wizard-title-container__icon {
        height: 32px;
    }

    .service-icon {
        width: 46px;
        height: 40px;
    }

    .icon-circle {
        width: 67.5px;
        height: 67.5px;
    }

    .icons-container {
        gap: 40px;
    }

    .icon-container {
        gap: 15px;
        max-width: 110px;
        letter-spacing: 0.4px;
        line-height: 22px;
    }

    .dashboard-main-container .services-features-container {
        gap: 50px;

        & .icons-container {
            justify-content: start;
        }

        & h3:not(.service-card__title) {
            margin-bottom: 24px;
        }
    }  

    .dashboard-news-container {
        padding: 60px var(--lr-padding) 70px;
        margin-bottom: -70px;
        gap: 50px;
    }

    .dashboard-main-container .services-features-container>div:not(:last-child) {
        border-width: 2px;
        padding-bottom: 50px;
    }

    .dashboard-main-container:not(:has(+.dashboard-news-container div)) .services-features-container .service-cards {
        grid-template-columns: 1fr 1fr;
        gap: 50px;
    }

    .service-top-container {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
        column-gap: var(--gutter);
        margin: var(--tb-margin) var(--lr-margin);        
    }

    .service-top-container__grid {
        grid-template-columns: repeat(auto-fill, minmax(400px, 1fr));
        grid-row: 1;
        grid-column: 1;
        gap: 50px;
        margin: 0;
    }

    .service-top-container:has(.service-top-container__grid div) .banner-carousel,
    .service-top-container:has(.service-top-container__grid div) .banner-container {
        grid-row: 1;
        grid-column: 2;
        align-self: flex-start;
    }

    .service-top-container:has(.service-top-container__grid div) .banner-carousel {
        container-type: anchored;
    }

    .info_faq::after {
        margin-left: 7px;
        width: 14px;
        height: 14px;
    }

    .credit-card-icon-wrapper {
        width: 62px;
        height: 38px;
    }

    .existing_card_choice .credit-card-icon-wrapper {
        width: 50px;
        height: 30px;
    }
    
    .credit-card-icon {
        width: 40px;
    }

    .service-title__icon-wrapper {
        padding: 35px 0 35px 50px;
    }

    .service-title__heading {
        margin-left: 50px;
        padding: 42px 50px 42px 30px;
    }

    .service-title__icon-wrapper::after {
        right: -50px;
    }

    .service-title__icon {
        width: 56px;
        height: 56px;
    }

    .service-title__action--edit {
        padding: 16px 50px 16px 30px;
        border-radius: 5px 0 0 5px;
    }

    .service-title__action .btn {
        border-radius: 25px;
    }

    .service-title__action--edit .pin-icon {
        height: 24px;
    }

    .service-title__button--edit::before {
        content: 'myAIRDRIE favourites';
    }

    .service-title__button--edit a::after {
        content: '';
    }

    .service-title__button--edit {
        display: flex;
        flex-wrap: nowrap;
        gap: 40px;
    }

    .page-title__container {
        padding: 42px var(--lr-padding);
    }

    .page-title__icon {
        width: 36px;
        height: 36px;
        margin-right: 20px;
    }

    .btn:not(.btn-link) {
        padding: 16px 30px;
        font-size: 16px;
        line-height: 24px;
        min-height: 24px;
        border-radius: 25px;
        gap: 12px;
    }
    
    .btn__img {
        height: 24px;
    }    

    .btn.btn-tertiary,
    .btn.btn-alert {
        border: 2px solid var(--navy);
    }

    .quick-link {
        padding: 16px 30px;
        align-content: center;
        width: 100%;        
        height: 100%;
        margin-bottom: 0;
    }

    .quick-links-container {
        display: grid;
        grid-template-columns: repeat(4, 1fr);        
        gap: 20px 30px;
    }

    .banner-container {
        border-radius: 5px;
    }
    
    .banner-content {
        padding: 30px;
    }

    .banner-img {
        border-top-left-radius: 5px;
        border-bottom-left-radius: 5px;
    }

    .banner-carousel__slide:has(.banner-container) {
        border-top-left-radius: 5px;
        border-top-right-radius: 5px;
    }    

    .banner-carousel .banner-container,
    .banner-carousel .banner-container .banner-img {
        border-bottom-left-radius: 0;
        border-bottom-right-radius: 0;
    }   

    .banner-carousel .banner-carousel__controls {
        border-bottom-left-radius: 5px;
        border-bottom-right-radius: 5px;
        padding: 13px 30px;
    }

    .banner-carousel .alert-banner-carousel__controls {
        border-radius: 0;
    }

    .banner-carousel__arrow {
        width: 12.5px;
        height: 20px;
        margin: 2px 0;
    }

    @container banner (width < 768px) {
        .banner-container .banner-img {
            border-top-right-radius: 5px;
            border-bottom-left-radius: 0;
        }       
    }
    
    .alert-banner-container {
        grid-area: alert;
    }

    .alert-banner {        
        padding: 30px 50px;
    }

    .alert-banner__icon-wrapper {
        margin-right: 15px;
    }

    .alert-banner__icon {
        width: 26px;
        height: 26px;
    }

    .alert-banner__close {
        padding-left: 50px;        
    }

    .alert-banner__close-icon {
        width: 18px;
        height: 18px;
    }

    .alert-banner__title {
        line-height: 28px;
    }

    .alert-banner__content:has(p) {
        margin-top: 10px;
    }

    .alert-banner__actions {
        gap: 24px;
        margin-top: 24px;
    }

    .alert-banner--emergency .alert-banner__content {
        padding-left: 41px;
    }

    .expanding-section__control_container {
        margin-top: 6px;
    }

    .alert-banner--emergency .expanding-section__control {
        width: 20px;
        height: 20px;       
    }

    .alert-banner--emergency .alert-banner__icon-wrapper {
        margin-top: 2px;
    }

    .alert-banner--emergency .expanding-section__header {
        padding: 24px 0;
    }

    .alert-banner__content {
        ul, p {
            margin-bottom: 1em;
        }
        li {
            margin-bottom: 0;
        }
    }
    
    #responseMessage .alert-banner__icon-wrapper::after {
        width: 26px;
        height: 26px;
    }

    .calendar-events-container {
        gap: 25px;
    }

    .calendar-event {
        gap: 15px;
        padding-bottom: 25px;
        border-width: 2px;
    }

    .calendar-content h4 {
        margin-bottom: 8px;
        line-height: 23px;
    }

    .calendar-content h4 a,
    .calendar-content p {
        line-height: 23px;
    }

    .calendar-date {
        font-size: 16px;
        line-height: 21px;
        padding: 10px 2px;
        width: 55px;
    }

    .calendar-date--range {
        min-width: 85px;
    }

    .calendar-icon {
        width: calc(40px * 1.25);
        height: calc(40px * 1.25);
    }

    .action-links-container {
        margin-top: 16px;
    }

    .service-card {
        padding: 30px;
    }

    .service-card__icon {
        width: 48px;
        height: 48px;
    }

    .service-card__title {
        margin-bottom: 12px;
    }

    .service-card__actions {
        margin-top: 24px;
    }

    .services-container .service-cards {
        column-gap: 50px;
    }

    .services-container .service-card {
        margin-bottom: 25px;
    }

    .cards-container .action-links-container {
        margin-top: 40px;
    }

    .favourites-save-icon {
        width: 21px;
        height: 21px;
    }

    .page-card {
        padding: 30px;
        border-radius: 5px;
        column-gap: 20px;
        grid-template-columns: minmax(58px, max-content) 1fr;
    }

    @container page-card (width >= 768px) {
        .page-card--search {
            grid-template-columns: auto 1fr 1fr;
            gap: 20px;
        }

        .page-card--search .page-card__content-wrapper {
            padding-right: 50px;
        }
    }

    .page-card__title {
        margin-bottom: 12px;
    }

    .page-card__input {       
        border-width: 2px; 
        padding: 16px 20px;
        font-size: 16px;
        line-height: 28px;
    }

    .page-card__submit {
        margin-top: 26px;
    }

    .page-card.has_error .page-card__input {        
        background-size: 20px;
        padding-left: 40px;
    }

    .page-card__submit-button {
        font-size: 16px;
        gap: 8px;
        padding: 12px 30px;
    }

    .page-card__icon{
        width: 58px;
        height: 58px;
    }

    .page-card__actions .btn {
        margin-top: 24px;
    }

    .page-card__actions a:not(.btn) {
        margin-top: 30px;
    }

    .page-card__charts {        
        gap: 26px;
    }    

    .chart-header {
       padding: 16px 16px 14px;
    }

    .chart-header h4 {
        font-size: 16px;        
        line-height: 20px;
    }

    .chart-content {
        padding: 10px 16px 14px;
    }
    
    .chart-content h5 {
        line-height: 24px;
    }

    .expanding-section--bordered {
        border-bottom-width: 2px;
    }
    
    .expanding-section--bordered:nth-child(1 of .expanding-section) {
        border-top-width: 2px;
    }

    .content_block.collapsible.light_blue .expanding-section {
        border: none;
    }

    .expanding-section__header {
        padding: 21px 0 24px;
    }

    .expanding-section:not(.expanding-section--highlight-card, .expanding-section--service) .expanding-section__header:has(.expanding-section__control:checked) {
        padding-bottom: 16px;
    }

    .expanding-section--highlight-card .expanding-section__header {
        padding-bottom: 24px;
    }

    .expanding-section--highlight-card .expanding-section__header:has(.expanding-section__control:checked) {
        padding-bottom: 15px;
    }

    .expanding-section__header .expanding-section__title {
        margin-bottom: 0;
        padding-right: 50px;
    }

    .expanding-section__header .expanding-section__title:has(+p) {
        margin-bottom: 12px;
    }

    .expanding-section__header-img {
        gap: 15px;
    }

    .expanding-section__header .icon-circle {
        width: 52px;
        height: 52px;
    }
    
    .expanding-section__header .service-icon {
        width: 38px;
        height: 38px;
    }

    .expanding-section__control {
        width: 25px;
        height: 25px;
    }

    .expanding-section__control::after {
        width: 10px;
        height: 10px;
        border-width: 0 4px 4px 0;
    }

    .expanding-section__expansion {
        padding-bottom: 34px;
    }

    .expanding-section__content p:not(:last-child, :has(+hr)) {
        margin-bottom: 34px;
    }

    .expanding-section--highlight-card .expanding-section__expansion, .content_block.collapsible.light_blue .expanding-section .expanding-section__expansion {
        padding-bottom: 38px;
    }

    .expanding-section__actions {
        margin-top: 50px;
        gap: 50px;
    }

    .expanding-section__actions:not(:last-child) {
        margin-bottom: 50px;
    }

    .expanding-section--highlight-card, .content_block.collapsible.light_blue .expanding-section {
        border-radius: 5px;
        padding: 0 30px;
    }

    .expanding-section--highlight-card:not(:last-child) {
        margin-bottom: 25px;
    }

    .expanding-section--highlight-card .info-items-container p {
        margin-bottom: 24px;
    }

    .expanding-section--highlight-card .info-items-container h4 {
        margin-bottom: 8px;
    }

    .expanding-section--highlight-card .pap .info-items-container p {
        margin-bottom: 10px;
    }

    .expanding-section__links:has(a, .btn-link) {
        row-gap: 22px;
    }

    .expanding-section-container--service:has(.expanding-strip) {
        margin: unset;
    }

    .expanding-section-container--service .action-links-container--account {
        margin: 0;
    }

    .expanding-strip {
        border-top: none;
        border-left-style: solid;
        border-left-width: 15px;
        border-radius: 3px;
        
        &:has(>.expanding-section--service >.expanding-section__header .expanding-section__control:checked),
        &:has(>.expanding-section--service.is-expanded) {
            border-bottom: none;
        }
    }

    .expanding-section--service .expanding-section__header-content p:not(:last-child) {
        margin-bottom: 8px;
    }

    .expanding-section--service>.expanding-section__header {
        padding: 22px 30px 25px;
        row-gap: 8px;
    }

    .expanding-section--service .expanding-section__header-content,
    .expanding-section--service .expanding-section__header-optional {        
        margin-right: 50px;
    }

    .expanding-section--service .expanding-section__header-optional {
        gap: 8px;
    }

    .expanding-section--service>.expanding-section__expansion {
        padding: 26px 30px 39px;
    }

    .highlight-card {
        padding: 31px 40px;
        border-radius: 5px;
    }

    td, th,
    .document-setting-row,
    .transaction-row {
        font-size: 17px;
        line-height: 26px;
        padding: 20px 30px;
    }

    table:not(:first-child),
    .collapsing-table-container:not(:first-child) {
        margin-top: 40px;
    }

    .user-banner {
        padding: 30px var(--lr-padding);
    }

    .manage-account-actions {
        padding: 30px 50px;
        border-radius: 5px;
        column-gap: var(--gutter);
    }

    .manage-account-action {
        gap: 16px;
    }

    .user-banner .manage-account-action {
        gap: 15px;
    }

    .manage-account-action__icon {
        width: 25px;
        height: 25px;
    }

    .manage-account-action a,
    .manage-account-action .btn-link {
        line-height: 20px;
    }

    .manage-account-actions .manage-account-action:not(:last-child),
    .account-member {     
        border-width: 2px;
    }

    .edit-info {
        gap: 50px;   
    }

    .favourites-sort-container {
        gap: 20px;
    }

    .favourites-sort__item {
        grid-template-columns: 50px 1fr auto;
        border-radius: 5px;
        padding-right: 30px;
    }

    .favourites-sort__service {
        padding: 22px 22px 22px 30px;
    }

    .ellipsis {   
        width: 5px;
        height: 21px;
    }

    .modal {
        width: 1020px !important;
    }
    
    .modal__header {
        padding: 60px 100px;
    }
    
    .modal__title {       
        font-size: 32px;
        line-height: 42px;
    }

    .modal__content {
        padding: 50px 100px;
    }
    
    .modal__actions {
        margin-top: 50px;
        gap: 50px;
    }

    .modal-close-icon {
        width: 29px;
        height: 29px;
    }

    .receipt-modal .modal__header {
        padding-bottom: 40px;
    }

    .receipt-modal .receipt__header {
        padding: 40px 0 50px;
        margin: 0 100px;
        border-width: 2px;

        & .header-image {
            margin-right: 0;
        }

        & .airdrie-logo {
            width: 136px;
            height: 42px;
        }
    }

    .receipt-modal .receipt__body {
        padding: 50px 100px;
    }

    .receipt__body .flex-row {
        flex-direction: row;
        column-gap: 40px;

        & div {
            width: 300px;
        }
    }

    .settings {
        padding: 24px 30px 26px;
    }

    .settings--communication .settings__summary {
        grid-template-columns: 1fr 1fr 1fr;
        grid-template-rows: 1fr;
        grid-auto-flow: row;
        column-gap: 50px;
    }

    .alerts-reminders {
        padding: 40px 0;
    }

    .alerts-reminders__action {
        margin-top: 50px;
    }

    .bordered-section {
        column-gap: 15px;
        border-width: 2px;
        padding: 30px 0;
    
        & .icon-circle {
            width: 46px;
            height: 46px;
        }
    
        & .service-icon {
            width: 31px;
            height: 31px;
        }
    }
    
    .bordered-sections:first-child,
    .bordered-sections:last-child {
        border-width: 2px;
    }

    .message-block {
        padding: 50px var(--lr-padding);
    }

    .message-block h2 {
        margin-bottom: 40px;
    }

    .message-block__icon {
        height: 135px;
        margin-bottom: 40px;
    }

    .message-banner {
        padding: 50px var(--lr-padding);
        gap: 100px;
    }

    .message-banner__icon {
        width: 87px;
    }

    .center-container .message-banner {
        padding: 50px 0;
    }

    .buttons-container--column {
        row-gap: 40px;
    }

    .pap .buttons-container--column {
        row-gap: 20px;
        margin-top: 30px;
    }

    .search-result-item,
    .search-result-item:first-child {
        padding: 40px 0;
        border-width: 2px;
    }

    .search-result-item p {
        margin-top: 25px;
    }

    #assessmentReportContainer {        
        column-gap: 50px;
        padding: 40px 30px;

        & td:nth-child(odd) {
            padding: 20px 15px 20px 20px;
        }
    
        & td:nth-child(even) {
            padding: 20px 20px 20px 15px;
        }  
    }       
}

@media (width >= 1680px) {
    .service-top-container__grid {
        grid-template-columns: repeat(auto-fill, minmax(500px, 1fr));
    }
}

/* Desktop Extended - 2560+px */
@media (width >= 2560px) {
    :root {
        --tb-padding: 50px;
        --lr-padding: 100px;
        --tb-margin: 60px;
        --lr-margin: 100px;
        --gutter: 100px;
    }

    body {
        font-size: 19px;
        line-height: 28px;
    }

    h1 {
        font-size: 32px;
        line-height: 42px;
    }

    h3 {
        font-size: 21px;
        line-height: 29px;
    }

    .content_block.collapsible .expanding-section__header .expanding-section__title,
    .expanding-section--highlight-card .expanding-section__title,
    .content_custom .expanding-section--bordered .expanding-section__title {
        font-size: 21px;
        line-height: 29px;
    }

    h4, .h4 {
        font-size: 19px;
        line-height: 28px;
    }

    h5 {
        font-size: 17px;
        line-height: 27px;
        margin-bottom: 25px;
    }

    h6 {
        font-size: 15px;
        line-height: 25px;
        margin-bottom: 23px
    }

    ol:not(:last-child, :has(+hr)),
    ul:not(:last-child, :has(+hr)) {
        margin-bottom: 56px;
    }

    li {        
        margin-bottom: 20px;
    }

    ul.subsection-list {
        margin-bottom: 40px;
    }

    a,
    .btn-link {
        font-size: 16px;
    }

    .link-icon {
        width: 19px;
        height: 19px;
    }

    .center-container {
        width: 1280px;
    }

    .content_block p:has(+ *:not(p, hr, ul, ol)),
    .modal__content p:has(+ *:not(p, hr, ul, ol)) {
        margin-bottom: 56px;
    }

    .content_block p:has(+ div),
    .modal__content p:has(+ div) {
        margin-bottom: 30px;
    }

    .responsive-list {
        columns: 3;
        column-gap: 50px;
    }

    .site-header__actions {
        gap: 80px;
    }

    .site-header__nav {
        padding: 0 60px;
    } 

    .site-footer {
        padding: 60px 100px 60px 50px;
    }

    .breadcrumb-container {
        margin-top: 28px;
    }

    .wizard-header__logo {
        margin-right: calc((100vw - 1280px)/2);
    }

    .wizard-header__content {
        padding-left: calc((100vw - 1280px)/2);
        padding-right: var(--lr-padding);
    }

    .wizard-steps__items {
        padding: 50px;
    }

    .wizard-steps__icon {
        height: 38px;
    }

    .wizard .services-container h2 {
        margin-bottom: 40px;
    }

    .icon-container {
        max-width: 120px;
    }

    .dashboard-container {
       grid-template-columns: 1.7fr;
    }

    .dashboard-news-container {
        padding: 60px 100px 70px 50px;
    } 

    .info_faq::after {
        width: 18px;
        height: 18px;
    }

    .quick-links-container {
        grid-template-columns: repeat(5, 1fr);
        gap: 25px 30px;
    }

    .banner-carousel .alert-banner-carousel__controls {       
        padding: 13px 100px 13px 50px;
    }

    .alert-banner {
        padding: 40px 100px 40px 50px;
    }

    .alert-banner__header {
        grid-template-areas: 
        "icon title close"
        "icon content close"
        "icon action action";
        grid-template-columns: fit-content(30px) max(1270px) 1fr;
    }

    .alert-banner__title {
        line-height: 29px;
    }

    .alert-banner.alert-banner--emergency {
        padding: 0 var(--lr-padding) 0 50px;
    }
    
    .calendar-events-container {
        gap: 27px;
    }

    .calendar-event {
        gap: 20px;
        padding-bottom: 27px;
    }

    .calendar-date {
        font-size: 17px;
        line-height: 22px;
    }

    .calendar-content h4,
    .calendar-content h4 a,
    .calendar-content p {
        line-height: 25px;
    }

    .action-links-container {
        margin-top: 25px;
    }

    .services-container .service-cards {
        column-count: 3;
    }

    .dashboard-main-container .services-features-container .service-cards {
        grid-template-columns: 1fr 1fr;
        gap: 50px;
    }

    @container page-card (width >= 1280px) {
        .page-card--search .page-card__content-wrapper {
            padding-right: 80px;
        }
    }

    .page-card__title {
        margin-bottom: 15px;
    }

    .chart-header h4 {
        font-size: 17px;        
        line-height: 21px;
    }

    .service-card__title {
        margin-bottom: 15px;
    }

    .expanding-section:not(.expanding-section--highlight-card, .expanding-section--service) .expanding-section__header {
        padding: 31px 20px 34px;

        &:has(.expanding-section__control:checked) {
            padding-bottom: 24px;
        }
    }

    .expanding-section__header .expanding-section__title {
        margin-bottom: 0;
    }

    .expanding-section:not(.expanding-section--highlight-card, .expanding-section--service) .expanding-section__expansion {
        padding: 0 20px 49px;
    }

    .expanding-section--highlight-card, .content_block.collapsible.light_blue .expanding-section {
        padding: 0 40px;
    }
    
    .expanding-section--highlight-card:not(:last-child) {
        margin-bottom: 30px;
    }

    .expanding-section--service>.expanding-section__header {
        row-gap: 11px;
    }

    .service-title__heading {
        max-width: 1270px;
    }

    .service-top-container__grid {
        gap: 60px;
    }    

    td, th,
    .document-setting-row,
    .transaction-row {
        font-size: 19px;
        line-height: 28px;
    }

    .manage-account-actions {
        padding: 45px var(--lr-padding);
    }

    .manage-account-action__icon {
        width: 30px;
        height: 30px;
    }

    .manage-account-action a,
    .manage-account-action .btn-link {
        line-height: 21px;
    }

    .favourites-sort__item {
        grid-template-columns: 60px 1fr auto;
    }

    .ellipsis {   
        width: 6px;
        height: 28px;
    }
    
    .settings--communication .settings__summary {
        column-gap: 30px;
    }

    .bordered-section {
        padding: 40px 0;
    }

    .message-block,
    .message-banner {
        padding: 60px var(--lr-padding);
    }

    .center-container .message-banner {
        padding: 60px 0;
    }

    .buttons-container {
        column-gap: 40px;
    }    
}

@media print {
    .no_print {
        display: none !important;
    }

    body:not(.show_modal) .modal {
        display: none;
    }

    body.show_modal header,
    body.show_modal .alert-banner-container,
    body.show_modal .dashboard-menu,
    body.show_modal nav,
    body.show_modal main,
    body.show_modal footer,
    body.show_modal .ui-widget-overlay {
        display: none;
    }
    
    .receipt-modal {
        & .modal__header {
            background-color: var(--white);
        }
               
        & .modal__title {
            color: var(--black);
        }

        & .receipt__header {
            display: flex;
            flex-direction: row;
            justify-content: space-between;
            background-color: var(--white);
            color: var(--black);
            padding: 0;
        }

        & .airdrie-logo {
            width: 136px;
            height: 42px;
            
            & path {
                fill: var(--black);
            }
        }

        & .modal__content {
            background-color: var(--white);
            color: var(--black);
        }

        .receipt__body .flex-row {
            flex-direction: row;
            column-gap: 40px; 
            justify-content: space-between;   
        }    
    }
}