<html><head><meta name="color-scheme" content="light dark"></head><body><pre style="word-wrap: break-word; white-space: pre-wrap;">.Campaign div.__pfs.tab-pane {padding-bottom: 0;}
.Campaign div.__pfs.tab-pane .py-2:not(.w-full) {padding: 0;}
.Campaign div.__pfs.tab-pane .py-2:not(.w-full) [data-em-cmp="price_widget"] {
    max-width: 1200px;
    width: 100%;
    margin: 0 auto;
}
.Campaign ul.__pfs.nav.nav-tabs.__pfs {width: 100%; margin-bottom: 0; border-bottom: 0;}
.Campaign div.__pfs.tab-content {width: 100%; margin: 0 auto; }
.Campaign .px-3, .Campaign .py-4 {
    padding: 0 !important
}

/* Footnote disclaimer below all grids */
p.__pfs.vg-f.tracking-normal.vg-e.vg-F.vg-g.vg-H.vg-I.vg-AA.vg-AB {
    font-size: 12px;
}
p.__pfs.Aw.tracking-normal.b.H.I.J.K.Db.Dc {
    font-size: 12px;
    background: #fff;
    padding: 20px !important;
}
p.__pfs[data-test='disclaimer'] a.__pfs {
    font-weight: 700;
    text-decoration: none;
}

@media only screen and (max-width: 1024px) {
    .Campaign .__pfs.row.__bss {margin: 0;}
}

.sun-hub .header-row h1.__pfs strong,.sun-hub .header-row h1.__pfs.__bss strong {
    font-size: 36px
}

.sun-hub .header-row h1.__pfs.__bss,:lang(fr) .sun-hub .header-row h1.__pfs.__bss {
    font-size: 30px
}

@media only screen and (min-width:1600px) {
    div.__pfs#acv img.__pfs:first-child {
        width: 100%
    }
}

.sun-hub .ae-content a.__pfs:hover:not(.primary-btn,[role=tab]) {
    text-decoration: underline!important
}

.error-check p.__pfs.__bss {
    color: #d8292f;
    font-size: 14px!important
}

.sun-hub h1.__pfs,.sun-hub h1.__pfs.__bss,.usa-hub h1.__pfs,.usa-hub h1.__pfs.__bss {
    font: 300 36px Open Sans;
    margin: 30px auto
}

.sun-hub h2.__pfs,.sun-hub h2.__pfs.__bss,.usa-hub h2.__pfs,.usa-hub h2.__pfs.__bss {
    text-align: center;
    font: 600 28px"Open Sans";
    margin: 0 auto 23px!important;
    padding: 20px 0 0;
    width: 70%
}

.sun-hub h2.__pfs.__bss:after,.sun-hub h2.__pfs:after,.usa-hub h2.__pfs.__bss:after,.usa-hub h2.__pfs:after {
    content: "";
    display: block;
    background-color: #bba88d;
    width: 20px;
    height: 2px;
    margin: 20px auto
}

.gradient-blue-bg:not(#acv,#earn-bonus-points) h2.__pfs.__bss:after,.gradient-blue-bg:not(#acv,#earn-bonus-points) h2.__pfs:after {
    display: none
}

#earn-bonus-points h2.__pfs.__bss:after,#earn-bonus-points h2.__pfs:after {
    margin: 20px 0-10px
}

.sun-hub h2.__pfs.__bss+p.__pfs,.usa-hub h2.__pfs.__bss+p.__pfs {
    font-size: 18px;
    width: 70%;
    margin: 0 auto 30px;
    text-align: center
}

.sun-hub h3.__pfs,.sun-hub h3.__pfs.__bss,.usa-hub h3.__pfs,.usa-hub h3.__pfs.__bss {
    font: 600 20px Open Sans
}

.sun-hub p.__pfs.__bss,.usa-hub p.__pfs.__bss {
    font: 14px Open Sans
}

.sun-hub .promoSection .promo-container div.__pfs h2.__pfs.__bss:after {
    margin: 20px 0
}

.sun-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs p.__pfs.__bss:first-child {
    display: flex;
    align-items: center;
    font-weight: 600;
    font-size: 16px
}
.__pfs.offer-panel.reg-panel-white.sun_points.__bss li {
    display: flex !important;
    align-items: center !important;
    gap: 20px !important;
}
#earn-bonus-points &gt; div &gt; div &gt; div:nth-child(1) &gt; div.__pfs.offer-panel.reg-panel-white.sun_points.__bss &gt; ul {
    padding: 0px !important;
}
#earn-bonus-points &gt; div &gt; div &gt; div:nth-child(1) &gt; div.__pfs.offer-panel.reg-panel-white.sun_points.__bss &gt; ul:nth-child(1) &gt; ul {
    padding: 0 !important;
}
#earn-bonus-points &gt; div &gt; div &gt; div:nth-child(1) &gt; div.__pfs.offer-panel.reg-panel-white.sun_points.__bss &gt; ul:nth-child(1) &gt; ul &gt; li img {
    width: 60px;
}
#earn-bonus-points &gt; div &gt; div &gt; div:nth-child(1) &gt; div.__pfs.offer-panel.reg-panel-white.sun_points.__bss &gt; ul:nth-child(3) &gt; li img {
    width: 60px;
}
div#flightOffers {
    background: linear-gradient(to bottom, #FFF -24%, #ddeef9 -42%) !important;
}
#earn-bonus-points &gt; div &gt; div &gt; div:nth-child(1) &gt; div.__pfs.offer-panel.reg-panel-white.sun_points.__bss {
    background: #fff;
    padding: 20px !important;
    border-radius: 14px;
    box-shadow: 0px 0px 15px -3px rgba(0, 0, 0, 0.2);
}
/* .__psc ul.__pfs {
    margin: 0 0 16px 0;
    padding: 0 10px !important;
    list-style: none !important;
} */
#earn-bonus-points &gt; div &gt; div &gt; div:nth-child(1) &gt; div.__pfs.grey-bg.__bss {
    background: none !important;
    padding: 15px 0px !important;
}
#earn-bonus-points &gt; div &gt; div &gt; div:nth-child(1) &gt; div {
    padding: 0px !important;
    max-width: 660px !important;
}
.__bss hr {
    margin-top: 10px !important;
    margin-bottom: 10px !important;
    border: 0;
    border-top: 3px solid #eee !important;
}
#earn-bonus-points &gt; div &gt; div &gt; div:nth-child(1) &gt; p {
    max-width: 680px !important;
    font-size: 14px;
}
.sun-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs p.__pfs.__bss:first-child span.__pfs,.sun-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs p.__pfs:first-child span.__pfs {
    width: 40px;
    height: 40px;
    background: #d8292f;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-right: 8px
}

.sun-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs p.__pfs.__bss:first-child span.__pfs img.__pfs,.sun-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs p.__pfs:first-child span.__pfs img.__pfs {
    width: 25px;
    height: auto
}

.sun-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs p.__pfs.__bss {
    font-size: 14px
}

.sun-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs p.__pfs.__bss:first-child+div.__pfs,.sun-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs p.__pfs.__bss:first-child+p.__pfs {
    padding-left: 48px
}

.sun-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs:nth-of-type(3) p.__pfs:first-child span.__pfs img.__pfs {
    width: 20px
}

.sun-hub .sun-promo-box .ntp-tooltip .copy-icon img.__pfs {
    filter: brightness(0) invert(1);
    margin: 0 6px 0 15px
}

section#aeroplan-offer {
    margin-top: 6em
}

div.__pfs#companion .row.box.white-panel .row.promotional-code p.__pfs.__bss {
    text-align: left
}

section#aeroplan-offer .ae-row .col-66 h2.__pfs.__bss {
    margin: 5px 0 20px
}

section#aeroplan-offer .ae-row .col-66 div.__pfs div.__pfs {
    flex-direction: column;
    margin-left: 40px;
    align-items: baseline
}

div.__pfs#join-aeroplan h3.__pfs.__bss,div.__pfs#join-aeroplan p.__pfs.__bss {
    text-align: center
}

div.__pfs#join-aeroplan h3.__pfs.__bss {
    margin: 10px 0
}

div.__pfs#join-aeroplan form {
    margin: 25px 0 15px
}

div.__pfs#join-aeroplan form img.__pfs {
    margin: 0 auto 20px
}

label#rules-check {
    display: block;
    overflow: hidden;
    padding-left: 10px;
    font-weight: 400!important
}

div.__pfs.tc-panel-container h3.__pfs,div.__pfs.tc-panel-container h3.__pfs.__bss {
    margin: 0;
    padding: 15px;
    position: relative;
    font-size: 16px
}

.item ul.__pfs,.tc-panel-content ul.__pfs {
    list-style: disc;
    padding-left: 20px
}

.sun-hub .grey-bg .ae-content p.__pfs.__bss,.usa-hub .grey-bg .ae-content p.__pfs.__bss {
    margin: 20px 0;
    flex: 1;
    border-left: 1px solid #c8c8c8;
    display: flex;
    justify-content: center;
    font-size: 18px
}

.sun-hub .grey-bg .ae-content p.__pfs a.__pfs,.sun-hub .grey-bg .ae-content p.__pfs.__bss a.__pfs,.usa-hub .grey-bg .ae-content p.__pfs a.__pfs,.usa-hub .grey-bg .ae-content p.__pfs.__bss a.__pfs {
    padding: 0 20px;
    text-align: CENTER
}

.sun-hub .grey-bg .ae-content p.__pfs a.__pfs img.__pfs,.sun-hub .grey-bg .ae-content p.__pfs.__bss a.__pfs img.__pfs,.usa-hub .grey-bg .ae-content p.__pfs a.__pfs img.__pfs,.usa-hub .grey-bg .ae-content p.__pfs.__bss a.__pfs img.__pfs {
    display: block;
    text-align: center;
    margin: 0 auto 10px;
    height: 24px
}

.sun-hub .grey-bg .ae-content p.__pfs.__bss:last-child,.usa-hub .grey-bg .ae-content p.__pfs.__bss:last-child {
    border-right: 1px solid #c8c8c8
}

.blue-bg .ae-content nav .nav-tabs li.__pfs.active {
    box-shadow: 5px 5px 5px 1px rgb(0 0 0/35%);
    z-index: 3;
    position: relative
}

.blue-bg .ae-content nav .nav-tabs li.__pfs a.__pfs span.__pfs {
    padding-bottom: 12px
}

.blue-bg .tab-content #california img.__pfs {
    display: inline-block;
    padding: 0 20px
}

.blue-bg .tab-content h3.__pfs.__bss+p.__pfs {
    width: 70%;
    margin: 0 auto 2em
}

.blue-bg .tab-content h3.__pfs,.blue-bg .tab-content h3.__pfs.__bss {
    width: 70%;
    margin: 0 auto 40px
}

div.__pfs#redeem-points .destination-container.ae-carousel .slick-slide div.__pfs:first-child:not(.item) {
    margin: 15px 7.5px
}

.destination-container .item div.__pfs p.__pfs.__bss+p.__pfs,div.__pfs#flight-pass .ae-content .description div.__pfs p.__pfs.__bss,div.__pfs#flight-pass .ae-content .white-panel div.__pfs p.__pfs.__bss {
    font-size: 14px
}

div.__pfs#hub-tabs .nav.nav-tabs.__pfs.__bss {list-style: none;}

div.__pfs#hub-tabs .nav.nav-tabs.__pfs.__bss li.__pfs.tab.active a.__pfs {
    font-weight: 600
}

div.__pfs#hub-tabs .nav.nav-tabs.__pfs.__bss li.__pfs.tab a.__pfs:hover {
        text-decoration: none;
}

div.__pfs#flight-pass .ae-content .white-panel div.__pfs h3.__pfs,div.__pfs#flight-pass .ae-content .white-panel div.__pfs h3.__pfs.__bss {
    margin: 0 0 10px
}

div.__pfs#flight-pass .ae-content .white-panel div.__pfs h3.__pfs.__bss:before,div.__pfs#flight-pass .ae-content .white-panel div.__pfs h3.__pfs:before {
    background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/sun-hub/icon-flightpass.svg)no-repeat center center;
    padding: 0 10px 0 0;
    margin-top: -12px;
    display: inline-block;
    content: "";
    width: 28px;
    height: 14px;
    background-size: 20px;
    filter: invert(21%) sepia(99%) saturate(1991%) hue-rotate(340deg) brightness(95%) contrast(97%)
}

div.__pfs#companion .row.box.white-panel .row.promotional-code p.__pfs.__bss:first-child strong,div.__pfs#companion .row.box.white-panel .row.promotional-code p.__pfs:first-child strong {
    vertical-align: super
}

div.__pfs#companion .row.box.white-panel .row.promotional-code p.__pfs.__bss:first-child+p.__pfs {
    padding-left: 52px;
    margin-top: -15px
}

div.__pfs#companion .row.box.white-panel .row.promotional-code p.__pfs.__bss:first-child+ul.__pfs {
    padding-left: 67px;
    margin-top: -15px;
    list-style: disc
}

div.__pfs#companion .row.box.white-panel .row.promotional-code p.__pfs.__bss:first-child+ul.__pfs li.__pfs:last-child,div.__pfs#companion .row.box.white-panel .row.promotional-code p.__pfs:first-child+ul.__pfs li.__pfs:last-child {
    margin-top: 15px
}

div.__pfs#companion .row.box.white-panel .ntp-tooltip button.block-align.copy-code .copy-icon img.__pfs {
    margin-right: 5px;
    filter: hue-rotate(187deg)
}

#tour-packages .tile a.__pfs {
    text-decoration: underline
}

div.__pfs#hub-tabs .nav.nav-tabs.__pfs.__bss li.__pfs.tab a.__pfs {
    display: flex;
    flex-direction: column;
    font-weight: 400;
    align-items: center;
    padding: 10px;
    height: 100%;
    font-size: 20px;
    justify-content: center;
    background: 0 0
}

div.__pfs#hub-tabs .nav.nav-tabs li.__pfs.tab a.__pfs img.__pfs,div.__pfs#hub-tabs .nav.nav-tabs.__pfs.__bss li.__pfs.tab a.__pfs img.__pfs {
    width: 90px;
    height: 90px;
    margin: 15px
}

div.__pfs#hub-tabs .nav.nav-tabs.__pfs.__bss li.__pfs.tab:hover a.__pfs {
    background: #fff;
    box-shadow: 0 9px 12px -3px rgba(0,0,0,.12)
}

div.__pfs#destination-tabs .nav.nav-tabs.__pfs.__bss li.__pfs.tab:hover a.__pfs {
    box-shadow: none
}

div.__pfs#destination-tabs .nav.nav-tabs.__pfs.__bss li.__pfs.tab a.__pfs,div.__pfs#tour-packages .item-container .item div.__pfs p.__pfs.__bss {
    font-size: 16px
}

div.__pfs#destination-tabs .nav.nav-tabs.__pfs.__bss {
    border-bottom: none;
    justify-content: center
}

.cabin-container .item h3.__pfs,.cabin-container .item h3.__pfs.__bss,div.__pfs#top-offers .item-container .item h3.__pfs,div.__pfs#top-offers .item-container .item h3.__pfs.__bss,div.__pfs#travel-perks .item-container .item h3.__pfs,div.__pfs#travel-perks .item-container .item h3.__pfs.__bss {
    font-weight: 700
}

div.__pfs#top-offers .item-container .item p.__pfs.__bss:last-child {
    margin: auto auto 0;
    font-size: 16px
}

div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50:first-child h2.__pfs.__bss,div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50:first-child p.__pfs.__bss {
    text-align: left;
    margin: 10px 0;
    width: 100%
}

div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50 .item-container .item .desc p.__pfs span.__pfs.blue,div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50 .item-container .item .desc p.__pfs.__bss span.__pfs.blue {
    display: block;
    color: #005078
}

div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50 .item-container .item .desc p.__pfs.__bss {
    text-align: center
}

div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50 .item-container .item .desc p.__pfs.__bss:last-child,div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50 .item-container .item .desc p.__pfs:last-child {
    font-size: 14px
}

.sun-hub .promoSection .promo-container div.__pfs h2.__pfs:after {
    margin: 20px 0
}

div.__pfs#earn-bonus-points div.__pfs.row .col-50 .item p.__pfs .blue,div.__pfs#earn-bonus-points div.__pfs.row .col-50 .item p.__pfs.__bss .blue {
    color: #d8292f;
    font-size: 42px;
    margin-right: 8px
}

div.__pfs#earn-bonus-points div.__pfs.row .col-50 .item p.__pfs.__bss:first-child {
    font-weight: 700;
    font-size: 20px
}

div.__pfs#earn-bonus-points div.__pfs.row .col-50 .item p.__pfs.__bss:last-child {
    font-size: 18px
}

div.__pfs#earn-bonus-points p.__pfs.__bss.grey-bg {
    display: flex;
    align-items: flex-start;
    padding: 15px 20px;
    font-size: 16px;
    margin: auto 0 0;
    width: 100%;
    max-width: 575px
}

div.__pfs#earn-bonus-points p.__pfs.__bss.grey-bg img.__pfs {
    width: 20px;
    height: 20px;
    margin-right: 10px
}

div.__pfs#advance-seat-selection .row .col-50.white-panel p.__pfs.__bss.promo {
    display: flex;
    align-items: center;
    margin: 20px 0 10px
}

span.__pfs.white-circle img.__pfs {
    width: 18px;
    height: 18px
}

div.__pfs#tour-packages p.__pfs+img.__pfs,div.__pfs#tour-packages p.__pfs.__bss+img.__pfs {
    width: 215px;
    margin: 0 auto 30px
}

div.__pfs#tour-packages .ae-content h2.__pfs.__bss+img.__pfs {
    margin: 40px auto;
    max-width: 250px
}

.gradient-gold-bg .ae-content .white-panel img.__pfs+div.__pfs p.__pfs.__bss,div.__pfs#tour-packages .item-container .item div.__pfs h3.__pfs.__bss,div.__pfs#tour-packages .item-container .item div.__pfs p.__pfs.__bss {
    text-align: left
}

div.__pfs#advance-seat-selection .row .col-50.white-panel p.__pfs.__bss,div.__pfs#flight-pass .item-container .item div.__pfs p.__pfs.__bss {
    text-align: left;
    font-size: 16px
}

.cabin-container .item p.__pfs.__bss:last-child,.gradient-gold-bg .ae-content .white-panel img.__pfs+div.__pfs p.__pfs.__bss:last-child,div.__pfs#travel-perks .item-container .item p.__pfs.__bss:last-child {
    margin-top: auto
}

div.__pfs#travel-perks .item-container .item ul.__pfs li.__pfs {
    text-align: left;
    font-size: 16px;
    margin-bottom: 7px
}

.sun-hub h2.__pfs.__bss+p.__pfs+p.__pfs,.usa-hub h2.__pfs.__bss+p.__pfs+p.__pfs {
    font-size: 16px
}

.destination-container .item div.__pfs p.__pfs.__bss:not(:last-child),.destination-container .item div.__pfs p.__pfs:not(:last-child) {
    border-bottom: 1px solid #c8c8c8;
    padding-bottom: 10px;
    font-weight: 700;
    font-size: 18px
}

.destination-container .item div.__pfs p.__pfs.__bss.booking-mask-popup,.destination-container .item div.__pfs p.__pfs.booking-mask-popup,div.__pfs#redeem-points img.__pfs {
    margin: 0 auto
}

.sun-hub h2.__pfs.__bss.gradient-clouds-bg,.usa-hub h2.__pfs.__bss.gradient-clouds-bg {
    padding: 50px 0 6em;
    width: 100%
}

.sun-hub h2.__pfs.__bss.gradient-clouds-bg+.ae-content,.usa-hub h2.__pfs.__bss.gradient-clouds-bg+.ae-content {
    margin-top: -13em
}

div.__pfs#family-travel h2.__pfs.__bss:after,div.__pfs#vacation-packages h2.__pfs.__bss:after {
    display: none
}

@media only screen and (min-width:1201px) {
    .sun-hub .ae-content,.usa-hub .ae-content {
        width: 1200px;
        margin: 0 auto
    }

    div.__pfs#hub-tabs .nav.nav-tabs.__pfs.__bss {
        width: 1200px;
        max-width: calc(100% - 40px);
        margin: auto;
        border-bottom: none;
        justify-content: center;
        align-items: end;
    }

    div.__pfs#tc-panel-container-companion,div.__pfs#tc-panel-container-companion+.tc-panel-content,div.__pfs#tc-panel-container-fp,div.__pfs#tc-panel-container-fp+.tc-panel-content,div.__pfs#tc-panel-container-seat,div.__pfs#tc-panel-container-seat+.tc-panel-content,div.__pfs.tc-panel-container,div.__pfs.tc-panel-container+.tc-panel-content {
        margin: 0 auto 10px;
        width: calc(1200px - 8em)!important;
        max-width: 1200px
    }

    div.__pfs.tc-panel-container {
        margin-top: 4em!important
    }

    div.__pfs#travel-perks .ae-content.gradient-grey-bg {
        padding: 0 12em;
        width: 100%;
        max-width: 100%
    }
}

@media only screen and (max-width:1201px) and (min-width:1025px) {
    .module-row.module-row--campaign_widget+.container {
        width: 100%;
        max-width: calc(100% - 100px)
    }

    .sun-hub .header-row,.usa-hub .header-row {
        justify-content: end
    }

    div.__pfs.tc-panel-container,div.__pfs.tc-panel-container+.tc-panel-content {
        width: calc(100% - 12em)!important
    }

    div.__pfs.tc-panel-container {
        margin-top: 4em!important
    }

    div.__pfs#earn-bonus-points p.__pfs.__bss.grey-bg {
        margin: 20px auto 0
    }

    .module-row.module-row--price_widget {
        padding: 0 30px
    }
}

@media only screen and (max-width:1200px) and (min-width:768px) {
    .sun-hub .sun-promo-box .sections:nth-of-type(2) {
        flex-wrap: wrap
    }

    .sun-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs:last-child {
        flex-basis: 100%;
        padding: 20px 0
    }

    .sun-hub .sun-promo-box .ntp-tooltip button.block-align.copy-code.primary-btn {
        width: fit-content;
        max-width: 255px
    }

    .sun-hub .nav.nav-tabs.__pfs.__bss,.usa-hub .nav.nav-tabs.__pfs.__bss {
        width: calc(100% - 60px);
        max-width: 100%;
        margin: 0 auto
    }

    div.__pfs#advance-seat-selection .row img.__pfs.col-50 {
        max-width: 600px;
        margin: 0 auto 20px
    }

    div.__pfs#earn-bonus-points div.__pfs.row .col-50 .item {
        width: 70%;
        padding-left: 35%
    }

    div.__pfs#earn-bonus-points div.__pfs.row .col-50.white-panel {
        margin-top: 3em
    }

    div.__pfs#flight-pass .item-container,div.__pfs#tour-packages .item-container {
        margin: 0 30px
    }

    div.__pfs#tour-packages .item-container .item {
        max-width: 100%;
        margin: 20px 0
    }

    div.__pfs#flight-pass {
        margin-top: 0
    }

    div.__pfs.tc-panel-content {
        margin: 0 auto;
        max-width: calc(100% - 60px)
    }

    div.__pfs#tc-panel-container-fp,div.__pfs#tc-panel-container-fp+.tc-panel-content {
        margin: 0 auto;
        max-width: calc(100% - 100px)
    }

    div.__pfs#tc-panel-container-seat,div.__pfs#tc-panel-container-seat+.tc-panel-content {
        margin: 0 auto;
        max-width: calc(100% - 30px)
    }

    .destination-container .item img.__pfs,div.__pfs#travel-perks .item-container .item img.__pfs {
        height: 140px
    }

    div.__pfs#flight-pass .item-container .item .fp-image {
        min-height: 260px;
        width: 300%
    }

    div.__pfs#flight-pass .item-container .item div.__pfs {
        display: flex;
        flex-direction: column
    }

    div.__pfs#flight-pass .item-container .item div.__pfs a.__pfs {
        margin-top: auto
    }

    div.__pfs#tc-panel-container-companion,div.__pfs#tc-panel-container-companion+.tc-panel-content {
        max-width: 100%
    }

    div.__pfs#travel-perks .ae-content.gradient-grey-bg {
        padding: 0 2em;
        width: 100%;
        max-width: 100%
    }

    .sun-hub ul.__pfs.slick-dots {
        margin: 10px auto
    }
}

@media only screen and (min-width:1025px) {
    .sun-hub .header-row,.usa-hub .header-row {
        height: 500px
    }

    div.__pfs#hub-tabs {
        padding-top: 110px
    }

    :lang(fr) div.__pfs#hub-tabs {
        padding-top: 140px
    }

    .sun-hub .ae-content.top,.usa-hub .ae-content.top {
        margin-top: -200px
    }

    .sun-hub .ae-content.top .module-row.module-row--price_widget .container,.sun-hub .nav.nav-tabs.__pfs.__bss li.__pfs img.__pfs,.usa-hub .ae-content.top .module-row.module-row--price_widget .container,.usa-hub .nav.nav-tabs.__pfs.__bss li.__pfs img.__pfs {
        max-width: 100%
    }

    .InteractiveMap {
        margin: 0-30px
    }

    .sun-hub .nav.nav-tabs.__pfs.__bss,.usa-hub .nav.nav-tabs.__pfs.__bss {
        display: flex
    }

    .sun-hub .nav.nav-tabs.__pfs.__bss li.__pfs,.usa-hub .nav.nav-tabs.__pfs.__bss li.__pfs {
        flex: 25%;
        border: 0
    }

    .sun-hub .nav.nav-tabs.__pfs.__bss li.__pfs a.__pfs {
        border-bottom: solid 4px transparent
    }

    .sun-hub .nav.nav-tabs.__pfs.__bss li.__pfs.active a.__pfs,.sun-hub .nav.nav-tabs.__pfs.__bss li.__pfs:hover a.__pfs {
        border: 0;
        border-bottom: solid 4px #005078;
        box-shadow: 0 12px 15px -4px rgba(0,0,0,.2)
    }

    .sun-hub #offer-tabs .nav.nav-tabs.__pfs.__bss li.__pfs.active a.__pfs,.sun-hub #offer-tabs .nav.nav-tabs.__pfs.__bss li.__pfs:hover a.__pfs {
        border: 0;
        border-bottom: solid 4px #005078;
        box-shadow: none
    }

    div.__pfs#destination-tabs .nav.nav-tabs.__pfs.__bss li.__pfs.tab a.__pfs {
        height: inherit;
        background: 0 0;
        box-shadow: none;
        margin: 0
    }

    div.__pfs#destination-tabs .nav.nav-tabs.__pfs.__bss li.__pfs:not(.active) a.__pfs {
        border-bottom: 1px solid gray
    }

    div.__pfs#destination-tabs .nav.nav-tabs.__pfs.__bss li.__pfs:hover a.__pfs {
        border-bottom: solid 4px #005078;
        box-shadow: none;
        background: 0 0!important
    }

    div.__pfs#destination-tabs {
        margin-top: 3em
    }

    div.__pfs#destination-tabs .nav.nav-tabs.__pfs.__bss li.__pfs {
        flex: none;
        width: 30%
    }
}

@media only screen and (max-width:1024px) and (min-width:768px) {
    .sun-hub .ae-content#top,.usa-hub .ae-content#top {
        margin-bottom: -80px
    }

    .sun-hub .header-row .hero-image {
        padding-left: 2em;
        height: 350px
    }

    .usa-hub .header-row .hero-image {
        padding-left: 2em;
        width: 100%;
        height: 350px
    }

    .sun-hub .header-row .hero-image {
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/sun-hub/hero-sun-tablet.png)no-repeat center center;
        background-size: cover;
        width: 100%!important
    }

    .InteractiveMap.active {
        padding: 0 20px;
    }

    div.__pfs#hub-tabs {
        margin-top: 6.5em!important
    }

    div.__pfs#top-offers .gradient-clouds-bg+.ae-content {
        padding: 0 10px 4em
    }

    div.__pfs#join-aeroplan {
        padding: 20px;
        margin: 0 0 30px 30px;
        background: #f9f9f9
    }

    div.__pfs#earn-bonus-points div.__pfs.row .col-50.white-panel {
        margin-top: 0
    }

    div.__pfs#earn-bonus-points .ae-content {
        padding: 4em 15px
    }

    div.__pfs#earn-bonus-points p.__pfs.__bss.grey-bg {
        margin-left: 0
    }

    .destination-container {
        display: flex!important;
        flex-wrap: wrap!important;
        background: #fff
    }

    div.__pfs#earn-bonus-points div.__pfs.row .col-50 .item {
        width: 100%;
        padding-left: 0
    }

    div.__pfs#join-aeroplan form .form-control {
        background: #fff
    }

    .sun-hub .grey-bg .ae-content p.__pfs.__bss:first-child,.usa-hub .grey-bg .ae-content p.__pfs.__bss:first-child {
        border-left: none
    }

    .sun-hub .grey-bg .ae-content p.__pfs.__bss:last-child,.usa-hub .grey-bg .ae-content p.__pfs.__bss:last-child {
        border-right: none
    }

    .sun-hub .grey-bg .ae-content,.usa-hub .grey-bg .ae-content {
        padding: 0
    }

    .blue-bg .ae-content {
        padding: 0;
        width: 100%
    }

    /*.sun-hub .nav.nav-tabs.__pfs.__bss,.usa-hub .nav.nav-tabs.__pfs.__bss {
        display: none;
    }*/

    .sun-hub .nav.nav-tabs.__pfs.__bss li.__pfs,.usa-hub .nav.nav-tabs.__pfs.__bss li.__pfs {
        flex: 25%
    }

    .sun-hub .nav.nav-tabs.__pfs.__bss li.__pfs img.__pfs,.usa-hub .nav.nav-tabs.__pfs.__bss li.__pfs img.__pfs {
        max-width: 100%
    }

    .blue-bg .tab-content {
        padding: 4em 30px
    }

    .module-row.module-row--campaign_widget+.container {
        width: 100%;
        max-width: calc(100% + 40px)
    }

    div.__pfs#flight-pass .ae-content .white-panel {
        padding: 30px 10px
    }

    #tour-packages .tile div.__pfs:last-child {
        padding: 0 20px 20px
    }

    div.__pfs#tour-packages .ae-content {
        padding: 4em 0
    }

    div.__pfs#tour-packages .item-container {
        margin: 30px;
        flex-direction: column
    }

    div.__pfs#tour-packages .item-container .item {
        max-width: 50%;
        flex-direction: column;
        margin: 0 auto 20px
    }

    div.__pfs#tour-packages .item-container .item img.__pfs,div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50,div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50.white-panel {
        width: 100%
    }

    div.__pfs#companion .row.box.white-panel .ntp-tooltip {
        width: 70%
    }

    div.__pfs#companion .row.box.white-panel .ntp-tooltip button.block-align.copy-code,div.__pfs.vertical-config#earn-bonus-points {
        flex-direction: column
    }

    .sun-hub .promoSection .promo-container {
        flex-direction: column;
        text-align: center;
        justify-content: center
    }

    .sun-hub .promoSection.gradient-blue-bg .promo-container {
        flex-direction: column-reverse;
        text-align: center;
        justify-content: center
    }

    .sun-hub .promoSection .promo-container div.__pfs+img.__pfs,.sun-hub .promoSection .promo-container img.__pfs+div.__pfs {
        padding: 2em
    }

    div.__pfs#travel-perks .item-container {
        flex: calc(50% - 40px);
        margin: 10px
    }

    div.__pfs#travel-perks .item-container .item div.__pfs {
        padding: 0 15px 20px
    }

    div.__pfs#travel-perks .item-container+p.__pfs {
        margin-left: 10px
    }

    .sun-hub .promoSection .promo-container img.__pfs {
        max-width: 525px;
        margin: 0 auto;
        width: 100%
    }

    .sun-hub .promoSection .promo-container div.__pfs&gt;* {
        text-align: center
    }

    .sun-hub .promoSection .promo-container div.__pfs h2.__pfs.__bss:after {
        margin: 20px auto
    }

    div.__pfs#advance-seat-selection .row,div.__pfs#earn-bonus-points .row {
        flex-direction: row
    }

    div.__pfs.vertical-config#earn-bonus-points p.__pfs.__bss.grey-bg {
        margin: 10px auto!important;
        width: 100%
    }

    div.__pfs#tc-panel-container-seat,div.__pfs#tc-panel-container-seat+.tc-panel-content {
        width: calc(100% - 180px)
    }

    div.__pfs#travel-perks .item-container .item {
        width: calc(50% - 30px);
        flex: calc(50% - 30px)
    }

    div.__pfs#travel-perks .item-container .item img.__pfs {
        height: 215px
    }

    div.__pfs.tc-panel-container,div.__pfs.tc-panel-container+.tc-panel-content {
        width: calc(100% - 60px)!important
    }

    .sun-hub h3.__pfs.__bss,.usa-hub h3.__pfs.__bss {
        font: 600 16px Open Sans
    }
}

@media only screen and (max-width:767px) {
    div.__pfs#hub-tabs {
        margin: 0
    }

    .sun-hub h1.__pfs.__bss,.usa-hub h1.__pfs.__bss {
        font-size: 32px;
        line-height: 1.12;
        margin-bottom: 10px
    }

    .sun-hub h2.__pfs.__bss,.usa-hub h2.__pfs.__bss {
        font-size: 24px;
        line-height: 1.12;
        margin-bottom: 12px;
        width: 95%;
        padding: 20px 0 0
    }

    .sun-hub .h2.__pfs-like,.usa-hub .h2.__pfs-like {
        font-size: 24px;
        margin: 25px auto;
        width: 95%
    }

    .sun-hub h3.__pfs.__bss,.usa-hub h3.__pfs.__bss {
        font-size: 16px;
        font-weight: 700
    }

    .sun-hub p.__pfs.__bss,.sun-hub ul.__pfs li.__pfs,.usa-hub p.__pfs.__bss,.usa-hub ul.__pfs li.__pfs {
        font-size: 14px!important
    }

    a.__pfs.backTop {
        margin-top: 4em
    }

    .sun-hub .sun-promo-box .sections:nth-of-type(2) {
        flex-direction: column
    }

    .sun-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs {
        padding: 10px 0
    }

    .sun-hub .sun-promo-box {
        padding: 20px 20px 0
    }

    .sun-hub .ae-content,.usa-hub .ae-content {
        padding: 2em 0
    }

    .sun-hub .ae-content.top,.usa-hub .ae-content.top {
        margin-top: -8em;
        padding: 20px 0
    }

    .sun-hub .header-row,.usa-hub .header-row {
        background: 0 0;
        height: auto
    }

    .sun-hub .header-row .hero-image {
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/sun-hub/hero-sun-mobile.png)no-repeat center center;
        background-size: cover;
        width: 100%!important;
        margin: 0
    }

    .sun-hub .ae-content#top,.usa-hub .ae-content#top {
        margin-top: -80px
    }

    div.__pfs#travel-perks .ae-content {
        padding: 0!important
    }

    .destination-container {
        width: 100%;
        padding: 0 20px 20px;
        background: #fff!important
    }

    .destination-container .slick-dots {
        bottom: 0
    }

    .destination-container .slick-dots li.__pfs:nth-child(n+6) {
        display: none
    }

    .destination-container .item {
        width: calc(100% - 30px)!important;
        flex: none;
        background: #fff;
        margin: 15px
    }

    #destination-tabContent .destination-container {
        justify-content: center
    }

    div.__pfs#top-offers .gradient-clouds-bg+.ae-content {
        margin-top: -12em
    }

    .destination-container .item img.__pfs {
        height: auto
    }

    .sun-hub div.__pfs.gradient-clouds-bg+.ae-content,.sun-hub h2.__pfs.__bss.gradient-clouds-bg+.ae-content,.usa-hub div.__pfs.gradient-clouds-bg+.ae-content,.usa-hub h2.__pfs.__bss.gradient-clouds-bg+.ae-content {
        margin-top: -6em
    }

    #destination-tabContent .destination-container .item,div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50,div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50.white-panel {
        width: 100%
    }

    div.__pfs.vertical-config#earn-bonus-points p.__pfs.__bss.grey-bg {
        margin: 10px auto!important;
        width: 100%
    }

    .cabin-container,div.__pfs#earn-bonus-points .row,div.__pfs#top-offers .item-container,div.__pfs#travel-perks .item-container,div.__pfs.vertical-config#earn-bonus-points,div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50 .item-container {
        flex-direction: column
    }

    div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50 .item-container .item {
        flex-direction: row
    }

    div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50 .item-container .item .desc p.__pfs.__bss {
        text-align: left
    }

    div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50 .item-container .item .desc p.__pfs.__bss:first-child {
        font-size: 20px!important
    }

    div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50 .item-container .item:last-child {
        border-left: none
    }

    div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50 .item-container .item .desc p.__pfs.__bss span.__pfs.blue {
        display: initial
    }

    .cabin-container .item,.cabin-container .item:nth-of-type(2) {
        margin: 20px
    }

    div.__pfs#top-offers .item-container .item {
        padding: 20px
    }

    div.__pfs#mll {
        margin: 0 20px
    }

    .covid-box {
        margin: 3em 20px 0
    }

    .sun-hub button.slick-next,.sun-hub button.slick-next:hover,.sun-hub button.slick-prev,.sun-hub button.slick-prev:hover,.usa-hub button.slick-next,.usa-hub button.slick-next:hover,.usa-hub button.slick-prev,.usa-hub button.slick-prev:hover {
        display: block!important;
        background: url(https://www.aircanada.com/content/dam/aircanada/loyalty-content/images/prev-arrow.svg)!important;
        background-size: 20px!important;
        top: 35%
    }

    .sun-hub button.slick-next,.sun-hub button.slick-next:hover,.usa-hub button.slick-next,.usa-hub button.slick-next:hover {
        transform: rotate(180deg)
    }

    div.__pfs#earn-bonus-points div.__pfs.row .col-50 {
        width: calc(100% - 30px)!important;
        margin: 10px auto!important
    }

    div.__pfs#earn-bonus-points div.__pfs.row .col-50 .item {
        margin: 12.5px auto;
        flex-direction: row;
        width: 85%
    }

    div.__pfs#earn-bonus-points div.__pfs.row .col-50 .item&gt;* {
        text-align: left
    }

    div.__pfs#earn-bonus-points .tc-panel-container {
        margin: 20px 15px 0;
        width: calc(100% - 30px)
    }

    div.__pfs#tc-panel-container-companion,div.__pfs#tc-panel-container-seat,div.__pfs.tc-panel-content {
        width: calc(100% - 30px)
    }

    div.__pfs#advance-seat-selection .row img.__pfs.col-50 {
        max-width: 400px;
        margin: 0 auto 10px
    }

    div.__pfs#advance-seat-selection .row .col-50.white-panel {
        margin: 20px auto;
        width: calc(100% - 60px)
    }

    div.__pfs#tour-packages .item-container {
        margin: 30px;
        flex-direction: column
    }

    div.__pfs#tour-packages .item-container .item {
        max-width: 100%;
        margin: 0 0 20px;
        flex-direction: column
    }

    div.__pfs#tour-packages .item-container .item img.__pfs {
        width: 100%
    }

    div.__pfs#flight-pass {
        margin-top: 0
    }

    div.__pfs#flight-pass .item-container {
        margin: 30px
    }

    div.__pfs#flight-pass .item-container .item {
        flex-direction: column
    }

    div.__pfs#flight-pass .item-container .item .fp-image {
        height: 200px
    }

    div.__pfs#tc-panel-container-fp,div.__pfs#tc-panel-container-fp+.tc-panel-content {
        width: calc(100% - 100px);
        margin: 0 auto
    }

    div.__pfs#mll .ae-carousel {
        margin-bottom: 15px
    }

    div.__pfs#mll .ae-carousel ul.__pfs.slick-dots {
        bottom: -10px;
        position: relative
    }

    #tour-packages .tile,div.__pfs#flight-pass .ae-content .description,section#aeroplan-offer .ae-row {
        flex-direction: column
    }

    div.__pfs#join-aeroplan {
        margin: 30px 0;
        text-align: left;
        padding: 10px 20px 0
    }

    div.__pfs#join-aeroplan,div.__pfs#join-aeroplan form .form-control {
        background: #f9f9f9
    }

    .sun-hub .grey-bg .ae-content p.__pfs.__bss:first-child,.usa-hub .grey-bg .ae-content p.__pfs.__bss:first-child {
        border-left: none
    }

    .sun-hub .grey-bg .ae-content p.__pfs.__bss:last-child,.usa-hub .grey-bg .ae-content p.__pfs.__bss:last-child {
        border-right: none
    }

    .sun-hub .grey-bg .ae-content,.usa-hub .grey-bg .ae-content {
        padding: 0
    }

    .sun-hub .nav.nav-tabs.__pfs.__bss li.__pfs.active a.__pfs:after,.sun-hub .nav.nav-tabs.__pfs.__bss li.__pfs.active:after,.usa-hub .nav.nav-tabs.__pfs.__bss li.__pfs.active a.__pfs:after,.usa-hub .nav.nav-tabs.__pfs.__bss li.__pfs.active:after,div.__pfs#destination-tabs .nav.nav-tabs.__pfs.__bss,div.__pfs#hub-tabs .nav.nav-tabs.__pfs.__bss,div.__pfs#hub-tabs .nav.nav-tabs.__pfs.__bss.is-open li.__pfs.active a.__pfs:after,div.__pfs#offer-tabs .nav.nav-tabs.__pfs.__bss,div.__pfs#offer-tabs .nav.nav-tabs.__pfs.__bss.is-open li.__pfs.active a.__pfs:after div.__pfs#destination-tabs .nav.nav-tabs.__pfs.__bss.is-open li.__pfs.active a.__pfs:after {
        display: none
    }

    .blue-bg .ae-content nav .nav-tabs li.__pfs a.__pfs,.sun-hub .promoSection .promo-container div.__pfs&gt;* {
        text-align: center
    }

    .blue-bg .ae-content nav .nav-tabs li.__pfs.active a.__pfs {
        color: #000
    }

    .blue-bg .ae-content {
        width: 100%;
        padding: 0
    }

    .sun-hub .nav.nav-tabs.__pfs.__bss,.usa-hub .nav.nav-tabs.__pfs.__bss {
        display: flex;
        flex-wrap: wrap;
        display: none;
    }

    .sun-hub .nav.nav-tabs.__pfs.__bss li.__pfs,.usa-hub .nav.nav-tabs.__pfs.__bss li.__pfs {
        flex: 50%
    }

    .blue-bg .tab-content {
        padding: 30px
    }

    .blue-bg .tab-content h3.__pfs.__bss+p.__pfs,.blue-bg .tab-content img.__pfs+p.__pfs {
        width: 90%;
        margin: 0 auto 2em
    }

    .module-row.module-row--campaign_widget+.container {
        width: 100%;
        max-width: calc(100% + 40px)
    }

    div.__pfs#flight-pass .ae-content .description div.__pfs {
        text-align: left;
        margin-bottom: 20px
    }

    div.__pfs#flight-pass .ae-content .description div.__pfs img.__pfs {
        margin: 0 20px;
        float: left;
        width: 85px;
        height: 85px
    }

    div.__pfs#flight-pass .ae-content .white-panel {
        padding: 0 20px;
        flex-direction: column
    }

    div.__pfs#flight-pass .ae-content .white-panel div.__pfs {
        padding: 20px 0;
        border-top: 1px solid #e6e6e6
    }

    .sun-hub .nav.nav-tabs.__pfs.__bss li.__pfs img.__pfs,.sun-hub .promoSection .promo-container img.__pfs,.usa-hub .nav.nav-tabs.__pfs.__bss li.__pfs img.__pfs {
        max-width: 100%
    }

    .sun-hub p.__pfs.__bss.mobile-content,.usa-hub p.__pfs.__bss.mobile-content {
        display: flex;
        align-items: center;
        justify-content: space-between;
        font-weight: 700!important;
        font-size: 16px!important;
        border-top: 1px solid #c8c8c8;
        padding: 15px;
        box-shadow: 0 3px 10px -3px rgba(0,0,0,.2);
        width: 100%;
        margin: 0 auto;
        text-align: center
    }

    div.__pfs#destination-tabs .nav.nav-tabs.__pfs.__bss.is-open li.__pfs.active,div.__pfs#destination-tabs .nav.nav-tabs.__pfs.__bss.is-open li.__pfs:hover,div.__pfs#destination-tabs .nav.nav-tabs.__pfs.__bss.is-open ul.__pfs li.__pfs:active,div.__pfs#hub-tabs .nav.nav-tabs.__pfs.__bss.is-open li.__pfs.active,div.__pfs#hub-tabs .nav.nav-tabs.__pfs.__bss.is-open li.__pfs:hover,div.__pfs#hub-tabs .nav.nav-tabs.__pfs.__bss.is-open ul.__pfs li.__pfs:active,div.__pfs#offer-tabs .nav.nav-tabs.__pfs.__bss.is-open li.__pfs.active,div.__pfs#offer-tabs .nav.nav-tabs.__pfs.__bss.is-open li.__pfs:hover,div.__pfs#offer-tabs .nav.nav-tabs.__pfs.__bss.is-open ul.__pfs li.__pfs:active,p.__pfs.mobile-content:hover {
        cursor: pointer
    }

    p.__pfs.mobile-content span.__pfs.dropdown {
        background: url(https://www.aircanada.com/content/dam/aircanada/loyalty-content/images/icon/chevron-down.svg)no-repeat center center;
        background-size: 10px 10px;
        display: block;
        width: 24px;
        height: 24px;
        -o-object-fit: contain;
        object-fit: contain;
        margin-left: 8px
    }

    .mobile-content.rotate span.__pfs.dropdown {
        transform: rotateZ(180deg)
    }

    div.__pfs#hub-tabs,  div.__pfs#offer-tabs, div.__pfs#destination-tabs {position: relative;}

    div.__pfs#hub-tabs .nav.nav-tabs.__pfs.__bss.is-open,div.__pfs#offer-tabs .nav.nav-tabs.__pfs.__bss.is-open div.__pfs#destination-tabs .nav.nav-tabs.__pfs.__bss.is-open {
        display: block;
        flex-direction: column;
        width: 100%;
        padding: 0;
        top: 55px;
        margin: 0 auto;
        position: absolute;
        z-index: 10;
        background: #fff;
        border: 1px solid #e6e6e6;
        box-shadow: 0 3px 10px -3px rgb(0 0 0 / 20%);
    }

    div.__pfs#hub-tabs .nav.nav-tabs.__pfs.__bss.is-open li.__pfs,div.__pfs#offer-tabs .nav.nav-tabs.__pfs.__bss.is-open li.__pfs div.__pfs#destination-tabs .nav.nav-tabs.__pfs.__bss.is-open li.__pfs {
        display: flex;
        font-size: 16px;
        width: 100%
    }

    div.__pfs#hub-tabs .nav.nav-tabs.__pfs.__bss.is-open li.__pfs span.__pfs,
    div.__pfs#offer-tabs .nav.nav-tabs.__pfs.__bss.is-open li.__pfs span.__pfs,
    div.__pfs#destination-tabs .nav.nav-tabs.__pfs.__bss.is-open li.__pfs span.__pfs {
        font-size: 16px;
    }

    div.__pfs#hub-tabs .nav.nav-tabs.__pfs.__bss.is-open li.__pfs a.__pfs,div.__pfs#offer-tabs .nav.nav-tabs.__pfs.__bss.is-open li.__pfs a.__pfs div.__pfs#destination-tabs .nav.nav-tabs.__pfs.__bss.is-open li.__pfs a.__pfs {
        display: flex;
        flex-direction: row;
        padding: 15px;
        justify-content: flex-start;
        align-items: center;
        border-bottom: none;
        text-align: left;
        box-shadow: none;
        width: 100%;
        font-size: 14px;
        color: #000
    }

    div.__pfs#offer-tabs .nav.nav-tabs.__pfs.__bss.is-open li.__pfs a.__pfs div.__pfs#destination-tabs .nav.nav-tabs.__pfs.__bss.is-open li.__pfs a.__pfs {
        padding: 5px 13px;
    }

    div.__pfs#hub-tabs .nav.nav-tabs.__pfs.__bss.is-open li.__pfs a.__pfs img.__pfs,div.__pfs#offer-tabs .nav.nav-tabs.__pfs.__bss.is-open li.__pfs a.__pfs img.__pfs div.__pfs#destination-tabs .nav.nav-tabs.__pfs.__bss.is-open li.__pfs a.__pfs img.__pfs {
        margin: 0 10px 0 0;
        width: 20px;
        height: 20px
    }

    div.__pfs#earn-bonus-points p.__pfs.__bss.grey-bg {
        margin: 0 auto 40px
    }

    div.__pfs#companion .row.box.white-panel div.__pfs.col-33 {
        height: 300px
    }

    .light-blue-bg,div.__pfs#companion .row.box.white-panel {
        width: 100%;
        flex-direction: column
    }

    div.__pfs#companion .row.box.white-panel .ntp-tooltip {
        width: 100%
    }

    div.__pfs#companion .row.box.white-panel .row.promotional-code p.__pfs.__bss:first-child+p.__pfs,div.__pfs#companion .row.box.white-panel .row.promotional-code p.__pfs.__bss:first-child+ul.__pfs {
        padding-left: 45px;
        margin-top: -10px
    }

    .sun-hub .promoSection .promo-container {
        flex-direction: column;
        text-align: center;
        justify-content: center;
        max-width: 500px
    }

    .sun-hub .promoSection .promo-container div.__pfs h2.__pfs.__bss:after {
        margin: 20px auto
    }

    .sun-hub .promoSection.gradient-blue-bg .promo-container {
        flex-direction: column-reverse;
        text-align: center;
        justify-content: center
    }

    .sun-hub .promoSection .promo-container div.__pfs+img.__pfs,.sun-hub .promoSection .promo-container img.__pfs+div.__pfs {
        padding: 15px
    }

    div.__pfs#travel-perks .item-container {
        flex: calc(50% - 40px);
        margin: 10px
    }

    div.__pfs#travel-perks .item-container .item div.__pfs {
        padding: 0 15px 20px
    }

    div.__pfs#travel-perks .item-container+p.__pfs {
        margin-left: 10px
    }

    div.__pfs#travel-perks .item-container .item {
        margin: 15px auto;
        max-width: 400px
    }

    .sun-hub .promoSection.gradient-blue-bg .promo-container div.__pfs {
        padding-right: 0
    }

    div.__pfs#flight-pass .item-container .item .fp-image {
        min-width: 0
    }

    div.__pfs.tc-panel-container,div.__pfs.tc-panel-container+.tc-panel-content {
        width: calc(100% - 60px)!important
    }
}

@media only screen and (max-width:767px) and (min-width:415px) {
    .sun-hub .header-row .hero-image,.usa-hub .header-row .hero-image {
        height: 300px!important
    }
}

@media only screen and (max-width:414px) {
    .sun-hub .header-row .hero-image,.usa-hub .header-row .hero-image {
        height: 250px!important
    }

    div.__pfs#family-travel {
        padding-bottom: 10em
    }

    div.__pfs#family-travel .ae-content img.__pfs.col-60 {
        width: 277px;
        height: 165px;
        align-self: flex-start;
        margin: 5em 0 0
    }
}

#offers .gradient-blue-bg .ae-content .promo-container .white-panel,#offers .gradient-blue-bg#acv .promo-container .white-panel img.__pfs {
    width: 100%
}

#offers .gradient-blue-bg:not(.vertical-config) .ae-content .white-panel p.__pfs,#offers .gradient-blue-bg:not(.vertical-config) .ae-content .white-panel p.__pfs.__bss {
    flex: 1;
    display: flex;
    align-items: center;
    margin: 0;
    justify-content: center;
    font-size: 16px
}

.promo-full p.__pfs.__bss {
    font-size: 16px
}

#offers .gradient-blue-bg#acv .promo-container .white-panel picture+div.__pfs a.__pfs,#offers .gradient-blue-bg#acv .promo-container .white-panel picture+div.__pfs h3.__pfs,#offers .gradient-blue-bg#acv .promo-container .white-panel picture+div.__pfs h3.__pfs.__bss,#offers .gradient-blue-bg#acv .promo-container .white-panel picture+div.__pfs p.__pfs,#offers .gradient-blue-bg#acv .promo-container .white-panel picture+div.__pfs p.__pfs.__bss {
    text-align: left;
    /* justify-content: flex-start; */
    justify-content: flex-end;
    flex-direction: column;
    align-items: flex-start;
}

#offers .gradient-blue-bg .ae-content .white-panel p.__pfs img.__pfs,#offers .gradient-blue-bg .ae-content .white-panel p.__pfs.__bss img.__pfs {
    margin-right: 20px;
    width: 24px;
    height: 24px
}

#offers .gradient-blue-bg .ae-content .white-panel p.__pfs.__bss.divider {
    flex: none;
    width: 1px;
    height: 30px;
    background-color: #979797
}

#offers #top-offers .ae-content .white-panel h2.__pfs,#offers #top-offers .ae-content .white-panel h2.__pfs.__bss,#offers #top-offers .ae-content .white-panel p.__pfs.__bss:not(.red-pill),#offers #top-offers .ae-content .white-panel p.__pfs:not(.red-pill) {
    width: 100%
}

#offers #top-offers .ae-content .white-panel p.__pfs,#offers #top-offers .ae-content .white-panel p.__pfs.__bss {
    flex: none;
    display: block;
    margin: 0 auto 15px
}

@media only screen and (min-width:768px) {
    .__pfs.gradient-blue-bg.gradient-gold-blue.__bss {
        padding-bottom: 50px;
    }
    
    div.__pfs#offer-tabs .nav.nav-tabs.__pfs.__bss {
        display: flex;
        justify-content: center
    }

    div.__pfs#offer-tabs .nav.nav-tabs.__pfs.__bss li.__pfs {
        flex: 0 0 25%;
        width: 25%
    }
}

#perks h2.__pfs.__bss+p.__pfs,div.__pfs#acv h2.__pfs+p.__pfs,div.__pfs#acv h2.__pfs.__bss+p.__pfs,div.__pfs#all-destinations .ae-content h2.__pfs+p.__pfs,div.__pfs#all-destinations .ae-content h2.__pfs.__bss+p.__pfs,div.__pfs#flight-pass h2.__pfs+p.__pfs,div.__pfs#flight-pass h2.__pfs.__bss+p.__pfs {
    margin: 10px auto 20px
}

div.__pfs#acv h2.__pfs+p.__pfs+img.__pfs,div.__pfs#acv h2.__pfs.__bss+p.__pfs+img.__pfs {
    margin: 40px auto
}

#offers .gradient-blue-bg#acv .promo-container .white-panel picture+div.__pfs {
    padding: 20px 40px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    height: 100%;
}

#offers .gradient-blue-bg#acv .promo-container .white-panel picture+div.__pfs p.__pfs a.__pfs,#offers .gradient-blue-bg#acv .promo-container .white-panel picture+div.__pfs p.__pfs.__bss a.__pfs {
    margin-top: 30px
}

.gradient-gold-bg .ae-content .white-panel img.__pfs+div.__pfs p.__pfs.__bss:last-child a.__pfs,.gradient-gold-bg .ae-content .white-panel img.__pfs+div.__pfs p.__pfs:last-child a.__pfs {
    font-weight: 600
}

div.__pfs#all-destinations .ae-content p.__pfs.__bss,div.__pfs#all-destinations .ae-content p.__pfs.__bss a.__pfs,div.__pfs#join-aeroplan h3.__pfs,div.__pfs#join-aeroplan p.__pfs {
    text-align: center
}

div.__pfs#all-destinations .ae-content p.__pfs.__bss a.__pfs {
    font-size: 14px;
    text-decoration: underline
}

div.__pfs#spotlight-destinations .white-panel img.__pfs div.__pfs+img.__pfs {
    flex: none;
    width: 100%;
    height: 100px
}

div.__pfs#travel-perks .white-panel p.__pfs.__bss {
    margin-bottom: 0
}

.sun-hub .promoSection .promo-container div.__pfs&gt;*,div.__pfs#family-travel h2.__pfs.__bss,div.__pfs#family-travel p.__pfs.__bss,div.__pfs#vacation-packages h2.__pfs.__bss,div.__pfs#vacation-packages p.__pfs.__bss {
    text-align: left;
    width: 100%
}

div.__pfs#family-travel p.__pfs.__bss,div.__pfs#spotlight-destinations .white-panel div.__pfs p.__pfs.__bss,div.__pfs#vacation-packages p.__pfs.__bss {
    font-size: 16px
}

div.__pfs#spotlight-destinations .white-panel div.__pfs &gt; * {text-align: left;}

div.__pfs#travel-perks .ae-content ul.__pfs {
    padding: 0 15px;
    list-style: disc;
    margin-bottom: 20px
}

div.__pfs#travel-perks .ae-content ul.__pfs li.__pfs {
    margin: 7px 0;
    font-size: 16px
}

@media only screen and (min-width:1600px) {
    div.__pfs#vacation-packages {
        background-size: contain;
        padding-bottom: 6em;
        padding-top: 6em
    }

    div.__pfs#family-travel {
        background: #f1f7fa url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/sun-hub/bg-airport.png)no-repeat bottom right;
        background-size: contain
    }

    div.__pfs#family-travel .ae-content img.__pfs.col-60 {
        margin-left: auto
    }
}

div.__pfs#vacation-promise .ae-content .panel-container div.__pfs p.__pfs.__bss {
    font-size: 14px;
    text-align: center
}

@media only screen and (max-width:1024px) and (min-width:768px) {
    div.__pfs#vacation-packages {
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/sun-hub/bg-beach-tablet.png)no-repeat bottom left;
        background-size: contain
    }

    div.__pfs#vacation-packages .ae-content {
        justify-content: start
    }

    div.__pfs#family-travel {
        background: #f1f7fa url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/sun-hub/bg-airport-tablet.png)no-repeat top right;
        background-size: contain
    }

    #sun-hub .ae-content {
        padding: 4em 0
    }

    #offers #top-offers .ae-content .white-panel,#offers .gradient-blue-bg .ae-content .white-panel,div.__pfs#offer-tabs .nav.nav-tabs.__pfs.__bss {
        width: calc(100% - 40px)
    }

    div.__pfs#offer-tabs .nav.nav-tabs.__pfs.__bss li.__pfs {
        flex: 0 0 50%;
        width: 50%
    }

    .module-row.module-row--price_widget {
        padding: 0 20px
    }

    #offers .gradient-blue-bg#acv .promo-container {
        padding: 0
    }

    .ae-content .ae-carousel-tablet {
        background: 0 0
    }

    .gradient-gold-bg .ae-content .white-panel {
        margin: 0;
        background: 0 0
    }

    .gradient-gold-bg .ae-content .slick-slide div.__pfs:first-child:not(.white-panel) {
        margin: 10px auto;
        width: 60%
    }

    button.slick-next:before,button.slick-prev:before {
        display: none
    }

    div.__pfs#destination-tabs .nav.nav-tabs.__pfs.__bss li.__pfs.tab:not(.active) a.__pfs,div.__pfs#hub-tabs .nav.nav-tabs.__pfs.__bss li.__pfs.tab:not(.active) a.__pfs,div.__pfs#offer-tabs .nav.nav-tabs.__pfs.__bss li.__pfs.tab:not(.active) a.__pfs {
        border-bottom: 1px solid #d0d0ce
    }

    div.__pfs#family-travel .ae-content,div.__pfs#spotlight-destinations .white-panel {
        flex-direction: column
    }

    div.__pfs#spotlight-destinations .white-panel img.__pfs {
        flex: 100%;
        width: 100%;
        height: 242px;
        object-fit: cover
    }

    div.__pfs#travel-perks .white-panel div.__pfs:not(.divider) {
        flex: 1;
        padding: 0 30px;
        align-self: self-start
    }

    div.__pfs#family-travel .ae-content .col-40,div.__pfs#family-travel .ae-content .col-60 {
        width: 100%
    }

    div.__pfs#family-travel .ae-content img.__pfs.col-60 {
        align-self: flex-start;
        margin-left: 12em
    }

    div.__pfs#vacation-packages .ae-content .col-40 {
        width: 70%
    }

    div.__pfs#vacation-promise .ae-content {
        padding: 4em 0
    }

    div.__pfs#vacation-promise .ae-content .panel-container {
        flex-wrap: wrap;
        margin: 4em auto
    }

    div.__pfs#vacation-promise .ae-content .panel-container div.__pfs {
        flex: 50%
    }
}

@media only screen and (max-width:767px) {
    div.__pfs#vacation-packages {
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/sun-hub/bg-beach-mobile.png)no-repeat bottom left;
        background-size: contain;
        padding-bottom: 10em
    }

    div.__pfs#spotlight-destinations .white-panel {
        flex-direction: column
    }

    div.__pfs#family-travel {
        background: #f1f7fa url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/sun-hub/bg-airport-mobile.png)no-repeat;
        padding-bottom: 16em;
        background-position: right bottom;
        background-size: 101%
    }

    #offers .gradient-blue-bg .ae-content .white-panel {
        width: 100%
    }

    div.__pfs#flightOffers {
        background-size: cover
    }

    div.__pfs#spotlight-destinations .white-panel img.__pfs {
        flex: 100%;
        width: 100%;
        height: 242px;
        object-fit: cover
    }

    #offers .gradient-blue-bg:not(#acv) .ae-content .white-panel:not(.sale-panel) {
        background: 0 0;
        box-shadow: none;
        flex-direction: column;
        padding: 20px 0
    }

    #offers .gradient-blue-bg:not(#acv) .ae-content .white-panel p.__pfs.__bss:not(.red-pill) {
        background: #fff;
        box-shadow: 0 6px 32px -19px rgb(0 0 0/30%),0 7px 16px -8px rgb(0 0 0/10%);
        padding: 20px;
        margin: 10px
    }

    #offers #top-offers .ae-content .white-panel p.__pfs.__bss {
        margin: 0 auto 10px;
        box-shadow: none!important;
        width: 100%
    }

    #offers .gradient-blue-bg:not(#acv) .ae-content .white-panel p.__pfs.__bss.divider {
        display: none
    }

    #offers #top-offers .ae-content .white-panel {
        width: calc(100% - 40px);
        background: #fff
    }

    #offers #top-offers .ae-content .white-panel .red-pill {
        color: #fff;
        margin: 10px auto;
        padding: 5px 15px;
        box-shadow: none;
        background: #f01428;
        width: -webkit-fit-content;
        width: -moz-fit-content;
        width: fit-content
    }

    div.__pfs#offer-tabs .nav.nav-tabs.__pfs.__bss li.__pfs {
        flex: 0 0 50%;
        width: 50%
    }

    .module-row.module-row--price_widget {
        padding: 0 20px
    }

    #offers .gradient-blue-bg#acv .promo-container {
        padding: 0
    }

    .ae-content .ae-carousel-tablet {
        background: 0 0
    }

    .gradient-gold-bg .ae-content .white-panel {
        margin: 0;
        background: 0 0
    }

    .gradient-gold-bg .ae-content .slick-slide div.__pfs:first-child:not(.white-panel) {
        margin: 10px auto;
        width: 60%
    }

    button.slick-next:before,button.slick-prev:before {
        display: none
    }

    #offers .gradient-blue-bg#acv .promo-container .promo-2col {
        flex-direction: column
    }

    #offers .gradient-blue-bg#acv .promo-container .promo-2col .white-panel {
        flex: 100%;
        width: 100%
    }

    #offers .gradient-blue-bg#acv .promo-container .promo-2col .white-panel:last-child {
        margin-left: 0
    }

    .promo-full {
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/sun-hub/sunhub-aug2023.jpg)no-repeat !important;
        background-position: 2% -20% !important;
    }

    .promo-full div.__pfs {
        width: 100%;
        padding: 20px;
        background: #fff;
        margin-top: 178px
    }

    div.__pfs#travel-perks .white-panel {
        flex-direction: column;
        width: 60%;
        margin-bottom: 40px
    }

    div.__pfs#travel-perks .white-panel div.__pfs.divider {
        width: 40px;
        height: 1px;
        margin: 40px auto;
        flex: none;
        background-color: #d0d0ce
    }

    div.__pfs#family-travel .ae-content img.__pfs.col-60 {
        width: 330px;
        height: 219px;
        align-self: flex-start;
        margin: 17em 0 0
    }

    div.__pfs#vacation-promise .promo-full {
        box-shadow: 0 0 10px -3px rgb(0 0 0/20%)
    }

    div.__pfs#family-travel .ae-content,div.__pfs#vacation-packages .ae-content,div.__pfs#vacation-promise .ae-content .panel-container {
        flex-direction: column
    }

    div.__pfs#vacation-packages .ae-content .col-40 {
        padding: 30px;
        display: block;
        width: 100%;
        margin-bottom: 6em
    }

    div.__pfs#travel-perks .white-panel div.__pfs:not(.divider) {
        width: 100%
    }

    .sun-hub p.__pfs.__bss.mobile-content.topLayer img.__pfs {
        width: 31px;
        height: 31px
    }

    .sun-hub p.__pfs.__bss.mobile-content.topLayer span.__pfs:not(.dropdown) {
        flex: none;
        margin-right: auto;
        margin-left: 15px
    }

    #offers .gradient-blue-bg #top-offers .ae-content {
        width: 100%
    }

    div.__pfs#destination-tabs .mobile-content {
        background: #fff;
        margin-top: 0;
    }
}

/*.Campaign.lg\:max-w-6xl.self-center,.module-row.module-row--campaign_widget .container {
    width: 100%;
    max-width: 100%;
    margin: 0;
    padding: 0
}

.px-3,.py-4 {
    padding: 0
}*/

.sun-hub .header-row h1.__pfs,:lang(fr) .sun-hub .header-row h1.__pfs {
    font-size: 30px
}

div.__pfs:focus {
    outline: 0!important;
    box-shadow: 0 0 10px -3px rgb(0 0 0/20%)
}

div.__pfs#acv .ae-content {
    margin-top: -45%;
    padding-bottom: 4em;
    position: relative
}

@media only screen and (min-width:1600px) {
    div.__pfs#acv img.__pfs:first-child {
        width: 100%
    }
}

div.__pfs#acv {
    background: linear-gradient(to bottom,#fff 60%,#e2eff7)
}

.backToTop,.booking-mask-popup,label#rules-check a.__pfs {
    font-weight: 600!important
}

.sun-hub .header-row {
    width: 100%;
    max-width: 100%
}

.sun-hub .header-row .hero-image {
    background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/sun-hub/hero-sun.png)no-repeat center center;
    background-size: cover;
    height: 500px!important;
    width: 100%!important;
    max-width: 100%
}

.sun-hub .ae-content#top {
    background-color: #fff;
    text-align: center;
    position: relative;
    z-index: 2;
    padding: 30px;
    margin-top: -120px
}

.sun-hub .ae-content {
    text-align: left;
    margin: 0 auto
}

p.__pfs.booking-mask-popup, .__pfs.__bss.booking-mask-popup,
p.__pfs.__bss.booking-mask-popup a.__pfs.__bss {
    color: #005078;
    cursor: pointer;
    margin: 30px auto;
    width: fit-content;
    border-radius: 20px;
}

.error-check p.__pfs,span.__pfs.red {
    color: #d8292f
}

.error-check p.__pfs {
    font-size: 14px!important
}

.blue-text {
    color: #005078
}

.gradient-clouds-bg {
    background: url(https://www.aircanada.com/content/dam/aircanada/loyalty-content/images/cloud-bg.svg)no-repeat top center,linear-gradient(to bottom,#f1f7fa,#fff);
    background-size: cover
}

.gradient-blue-bg {
    background: linear-gradient(to top,#fff,#e2eff7 110%)
}

.gradient-top-blue-bg {
    background: linear-gradient(to top,#fff,#dfedf5 110%)
}

.gradient-grey-bg {
    background: linear-gradient(to bottom,#f2f5f7,#fff)
}

.gradient-gold-bg {
    background: linear-gradient(to bottom,#f7f5f1,#fff);
    margin-bottom: 30px
}

.first-panel-bg {
    background: linear-gradient(to bottom,#f7f5f1,#fff)!important
}

.pink-gradient-bg {
    background: linear-gradient(to top,#fff,#f9f8f6)
}

.pale-blue-gradient-bg {
    background: linear-gradient(to top,#fff,#dfe7ec)
}

.grey-bg {
    background: #f9f9f9
}

.light-blue-bg {
    background: #f1f7fa;
    margin: 20px auto 0;
    padding: 15px;
    display: flex;
    justify-content: space-between;
    align-items: center
}

.sun-hub .h2.__pfs-like,.usa-hub .h2.__pfs-like {
    text-align: center;
    font: 600 28px"Open Sans";
    margin: 40px auto!important;
    width: 85%
}

.sun-hub .text18,.sun-hub h2.__pfs+p.__pfs,.usa-hub .text18,.usa-hub h2.__pfs+p.__pfs {
    font-size: 18px;
    width: 70%;
    margin: 0 auto 30px;
    text-align: center
}

.sun-hub p.__pfs,.sun-hub ul.__pfs li.__pfs,.usa-hub p.__pfs,.usa-hub ul.__pfs li.__pfs {
    font: 14px Open Sans
}

.sun-hub .push-left {
    text-align: left;
    margin-bottom: 15px
}

.sun-hub .promoSection.gradient-blue-bg {
    display: block
}

.sun-hub .promoSection.gradient-blue-bg .ae-content {
    padding-bottom: 0
}

.sun-hub .promoSection .promo-container {
    margin: 20px auto 0;
    padding: 15px;
    display: flex;
    justify-content: space-between;
    align-items: flex-start
}

.sun-hub .promoSection .promo-container img.__pfs {
    max-width: 525px
}

.sun-hub .promoSection .promo-container img.__pfs+div.__pfs {
    padding-left: 4em
}

.sun-hub .promoSection.gradient-blue-bg .promo-container div.__pfs {
    padding-right: 4em
}

.sun-hub .sun-promo-box {
    background: #fff;
    box-shadow: 0 0 7px -3px rgb(84 84 84/75%);
    padding: 15px 4em 0;
    text-align: left
}

.sun-hub .sun-promo-box .sections:nth-of-type(1) {
    border-bottom: 2px solid #e6e6e6
}

.sun-hub .sun-promo-box .sections:nth-of-type(1) p.__pfs:last-child {
    margin-bottom: 35px
}

.sun-hub .sun-promo-box .sections:nth-of-type(2) {
    display: flex
}

.sun-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs {
    flex: 1;
    padding: 20px
}

.sun-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs p.__pfs:first-child {
    display: flex;
    align-items: center;
    font-weight: 600;
    font-size: 16px
}

.sun-hub .sun-promo-box .sections:nth-of-type(1) p.__pfs,.sun-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs p.__pfs {
    font-size: 14px
}

.sun-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs:first-child {
    padding-left: 0
}

.sun-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs p.__pfs:first-child+div.__pfs,.sun-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs p.__pfs:first-child+p.__pfs {
    padding-left: 48px
}

.sun-hub .sun-promo-box .ntp-tooltip button.block-align.copy-code.primary-btn {
    width: 100%;
    margin: 10px 0
}

.sun-hub .sun-promo-box .ntp-tooltip {
    padding: 0 0 0 48px!important
}

.sun-hub .sun-promo-box .ntp-tooltip .copy-icon,div.__pfs#companion .row.box.white-panel .ntp-tooltip button.block-align.copy-code .copy-icon,div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50 .item-container,section#aeroplan-offer .ae-row {
    display: flex
}

.sun-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs:last-child {
    padding-right: 0
}

div.__pfs#companion .row.box.white-panel .row.promotional-code p.__pfs,div.__pfs#flight-pass .ae-content .white-panel div.__pfs&gt;*,section#aeroplan-offer .ae-row .col-66 {
    text-align: left
}

section#aeroplan-offer .ae-row .col-66 img.__pfs {
    height: 17px
}

section#aeroplan-offer .ae-row .col-66 h2.__pfs {
    margin: 5px 0 20px
}

section#aeroplan-offer .ae-row .col-66 div.__pfs img.__pfs {
    height: 100px;
    width: 100px
}

section#aeroplan-offer .ae-row .col-66 div.__pfs {
    display: flex;
    align-items: center
}

div.__pfs#join-aeroplan {
    margin: 0 0 30px 3em;
    text-align: left
}

div.__pfs#join-aeroplan h3.__pfs {
    margin: 10px 0
}

div.__pfs#join-aeroplan form .form-control {
    border: 0;
    border-bottom: 1px solid #e6e6e6;
    box-shadow: none;
    border-radius: 0;
    padding: 10px
}

input#acDbaasRulesCheck,input#agreement {
    float: left
}

input#acDbaasSubmit,input#sign-up {
    float: none;
    margin: 20px auto;
    padding: 12px 45px;
    border-radius: 20px;
}

a.__pfs.backToTop {
    text-decoration: none;
    margin: 3em auto 0;
    text-align: center;
    display: flex;
    justify-content: center
}

div.__pfs.tc-panel-container {
    text-align: left;
    position: relative;
    cursor: pointer;
    background: #fff
}

.tc-panel-content {
    padding: 30px 15px 15px;
    text-align: left;
    border: 1px solid #e6e6e6;
    display: none;
    width: calc(100% - 30px)
}

.sun-hub .grey-bg .ae-content,.usa-hub .grey-bg .ae-content {
    display: flex;
    padding: 0 20px;
    margin: 40px auto
}

.sun-hub .grey-bg .ae-content p.__pfs,.usa-hub .grey-bg .ae-content p.__pfs {
    margin: 20px 0;
    flex: 1;
    border-left: 1px solid #c8c8c8;
    display: flex;
    justify-content: center;
    font-size: 18px
}

.sun-hub .grey-bg .ae-content p.__pfs:last-child,.usa-hub .grey-bg .ae-content p.__pfs:last-child {
    border-right: 1px solid #c8c8c8
}

.blue-bg {
    background-image: linear-gradient(to top,#fff,#cde4f3)
}

.blue-bg .ae-content {
    padding: 0
}

.blue-bg .ae-content nav .nav-tabs li.__pfs a.__pfs {
    background: #fff;
    display: flex;
    flex-direction: column;
    padding: 12px 0 0;
    border-bottom: none;
    margin: 0;
    border-top: 3px solid transparent;
    font-size: 14px
}

.blue-bg .ae-content nav .nav-tabs li.__pfs.active a.__pfs {
    border-top: solid 3px #005078
}

.blue-bg .tab-content {
    padding: 6em 0;
    text-align: center
}

.blue-bg .tab-content img.__pfs {
    max-width: 250px;
    margin: 0 auto 40px
}

.blue-bg .tab-content h3.__pfs+p.__pfs,.blue-bg .tab-content img.__pfs+p.__pfs {
    width: 70%;
    margin: 0 auto 2em
}

div.__pfs#redeem-points .destination-container.ae-carousel {
    background: 0 0;
    padding: 0 20px
}

div.__pfs#redeem-points .destination-container.ae-carousel .item {
    margin: 0;
    box-shadow: 0 0 10px -3px rgb(0 0 0/20%)
}

div.__pfs#all-destination .ae-content {
    padding-bottom: 0
}

div.__pfs#flight-pass {
    background-size: cover
}

div.__pfs#flight-pass .ae-content {
    padding: 4em 0 2em
}

div.__pfs#flight-pass .ae-content .description {
    display: flex;
    margin: 3em 0 20px
}

div.__pfs#flight-pass .ae-content .description div.__pfs {
    flex: 1;
    text-align: CENTER
}

div.__pfs#flight-pass .ae-content .description div.__pfs img.__pfs {
    width: 100px;
    height: 100px;
    margin: 0 auto 15px
}

.destination-container .item div.__pfs p.__pfs+p.__pfs,div.__pfs#flight-pass .ae-content .description div.__pfs p.__pfs,div.__pfs#flight-pass .ae-content .white-panel div.__pfs a.__pfs,div.__pfs#flight-pass .ae-content .white-panel div.__pfs p.__pfs {
    font-size: 14px
}

div.__pfs#flight-pass .ae-content .white-panel {
    display: flex;
    margin: 30px 0
}

div.__pfs#flight-pass .ae-content .white-panel div.__pfs {
    flex: 1;
    text-align: left;
    padding: 0 20px;
    display: flex;
    flex-direction: column
}

#offers .gradient-blue-bg#acv .promo-container .white-panel a.__pfs,div.__pfs#flight-pass .ae-content .white-panel div.__pfs a.__pfs,div.__pfs#hub-tabs .nav.nav-tabs li.__pfs.tab.active a.__pfs {
    font-weight: 600
}

div.__pfs#flight-pass .ae-content .white-panel div.__pfs a.__pfs:last-child {
    margin-top: auto
}

div.__pfs#companion .row.box.white-panel .row.promotional-code p.__pfs:first-child+p.__pfs {
    padding-left: 52px;
    margin-top: -15px
}

div.__pfs#companion .row.box.white-panel .row.promotional-code p.__pfs:first-child+ul.__pfs {
    padding-left: 67px;
    margin-top: -15px;
    list-style: disc
}

div.__pfs#companion .row.box.white-panel .ntp-tooltip button.block-align.copy-code {
    width: 100%;
    display: flex;
    justify-content: space-between
}

div.__pfs#companion .row.box.white-panel .ntp-tooltip {
    border: 1px solid #005078;
    border-radius: 6px;
    color: #005078;
    padding: 10px;
    font-weight: 700;
    width: 50%;
    background: #fff
}

div.__pfs#companion .row.box.white-panel {
    width: 80%;
    margin: 0 auto;
    padding: 0;
    display: flex
}

div.__pfs#companion a.__pfs.primary-btn.booking-mask-popup {
    margin: 35px auto
}

div.__pfs#companion .row.box.white-panel div.__pfs.col-33 {
    padding: 0;
    background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/sun-hub/companion-offer.jpg)no-repeat center center;
    background-size: cover;
    display: block
}

div.__pfs#companion .row.box.white-panel .row.promotional-code,div.__pfs#spotlight-destinations .white-panel div.__pfs {
    padding: 20px
}

div.__pfs#tour-packages {
    position: relative;
    margin-top: 2em
}

div.__pfs#tour-packages img.__pfs.tour-packagesLogo {
    width: 145px
}

#tour-packages .tile:nth-of-type(1) {
    margin-top: 4em
}

#tour-packages .tile {
    box-shadow: 0 0 15px 0 rgb(0 0 0/15%);
    display: flex;
    margin: 20px 0 0
}

#tour-packages .tile:hover {
    cursor: pointer;
    box-shadow: 0 0 20px 0 rgb(0 0 0/25%)
}

#tour-packages .tile div.__pfs {
    flex: 50%
}

#tour-packages .tile div.__pfs:last-child {
    padding: 0 30px 30px
}

#tour-packages .tile div.__pfs img.__pfs {
    width: 100%;
    height: 100%;
    object-fit: cover
}

.offer {
    box-shadow: 0 11px 15px rgb(0 0 0/10%);
    background: #fff;
    text-align: left
}

.offer--price {
    color: #004060;
    font-weight: 700
}

.blue-bg .tab-content .module-row.module-row--price_widget {
    background: rgba(255,255,255,.7);
    padding: 0 15px
}

div.__pfs#hub-tabs .nav.nav-tabs li.__pfs.tab a.__pfs {
    display: flex;
    flex-direction: column;
    font-weight: 400;
    align-items: center;
    padding: 10px;
    height: 100%;
    font-size: 20px;
    justify-content: center;
    background: 0 0
}

div.__pfs#hub-tabs .nav.nav-tabs li.__pfs.tab:hover a.__pfs {
    background: #fff;
    box-shadow: 0 9px 12px -3px rgba(0,0,0,.12)
}

div.__pfs#destination-tabs .nav.nav-tabs li.__pfs.tab:hover a.__pfs {
    box-shadow: none
}

div.__pfs#destination-tabs .nav.nav-tabs li.__pfs.tab a.__pfs,div.__pfs#tour-packages .item-container .item div.__pfs p.__pfs {
    font-size: 16px
}

div.__pfs#destination-tabs .nav.nav-tabs {
    border-bottom: none;
    justify-content: center
}

div.__pfs#top-offers .item-container {
    display: flex;
    padding: 30px 0 6em
}

div.__pfs#top-offers .gradient-clouds-bg+.ae-content {
    padding-top: 0;
    padding-bottom: 0;
    text-align: center
}

div.__pfs#top-offers .item-container .item {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 0 20px
}

div.__pfs#top-offers .item-container .item img.__pfs {
    width: 90px;
    height: 90px
}

div.__pfs#top-offers .item-container .item p.__pfs:last-child {
    margin: auto auto 0;
    font-size: 16px
}

div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50:first-child h2.__pfs,div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50:first-child p.__pfs {
    text-align: left;
    margin: 10px 0;
    width: 100%
}

div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50 .item-container .item {
    flex: 1;
    flex-direction: column;
    align-items: center;
    padding: 0 20px;
    margin: 30px 0
}

div.__pfs#acDbaasRegistered .primary-btn+a.__pfs,div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50 .item-container .item .desc p.__pfs {
    text-align: center
}

div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50 .item-container .item:last-child {
    border-left: 1px solid #c8c8c8
}

div.__pfs#earn-bonus-points .tc-panel-container {
    margin: 20px 0
}

div.__pfs#earn-bonus-points div.__pfs.row .col-50 {
    width: calc(60% - 30px);
    display: flex;
    flex-direction: column
}

div.__pfs#earn-bonus-points div.__pfs.row .col-50.white-panel {
    margin: 0 0 0 auto;
    width: 40%;
    background: #fff
}

div.__pfs#earn-bonus-points div.__pfs.row .col-50 .item {
    display: flex;
    margin-bottom: 20px;
    align-items: center
}

div.__pfs#earn-bonus-points div.__pfs.row .col-50 .item img.__pfs {
    width: 80px;
    height: 80px;
    margin-right: 15px
}

div.__pfs#earn-bonus-points div.__pfs.row .col-50 .item p.__pfs:first-child {
    font-weight: 700;
    font-size: 20px
}

div.__pfs#earn-bonus-points div.__pfs.row .col-50 .item p.__pfs:last-child {
    font-size: 18px
}

p.__pfs.conditional {
    text-align: center!important
}

div.__pfs#earn-bonus-points p.__pfs.grey-bg {
    display: flex;
    align-items: flex-start;
    padding: 15px 20px;
    font-size: 16px;
    margin: auto 0 0;
    width: 100%;
    max-width: 575px
}

div.__pfs#earn-bonus-points p.__pfs.grey-bg img.__pfs {
    width: 20px;
    height: 20px;
    margin-right: 10px
}

div.__pfs#advance-seat-selection .row {
    display: flex;
    flex-wrap: wrap;
    justify-content: center
}

a.__pfs.primary-btn,div.__pfs#advance-seat-selection .primary-btn {
    width: fit-content;
    margin: 20px auto
}

span.__pfs.white-circle {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    margin-right: 10px;
    display: inline-flex;
    box-shadow: 0 0 15px -3px rgb(0 0 0/20%);
    justify-content: center;
    align-items: center;
    background: #fff
}

div.__pfs#advance-seat-selection .row .col-50.white-panel p.__pfs {
    text-align: left;
    font-size: 16px
}

div.__pfs#advance-seat-selection .row .col-50.white-panel div.__pfs:not(.light-blue-panel) {
    padding: 20px
}

div.__pfs#advance-seat-selection .row .col-50.white-panel {
    padding: 0
}

div.__pfs#advance-seat-selection .row img.__pfs.col-50 {
    margin: 30px -15px 30px 0;
    max-width: 375px
}

div.__pfs#advance-seat-selection .row .col-50.white-panel p.__pfs.promo {
    display: flex;
    align-items: center;
    margin: 20px 0 10px
}

div.__pfs#tour-packages .ae-content {
    text-align: center;
    padding-top: 10px
}

div.__pfs#tour-packages .item-container {
    display: flex;
    margin: 0 8em;
    justify-content: center
}

div.__pfs#tour-packages .item-container .item {
    flex: 1;
    max-width: 100%;
    margin: 0 20px;
    display: flex;
    box-shadow: 0 0 15px -3px rgb(0 0 0/20%)
}

div.__pfs#tour-packages .ae-content h2.__pfs+img.__pfs {
    margin: 40px auto;
    max-width: 250px
}

div.__pfs#tour-packages .item-container .item img.__pfs {
    width: 50%
}

div.__pfs#tour-packages .item-container .item div.__pfs {
    padding: 0 20px 20px;
    height: 100%;
    display: flex;
    flex-direction: column
}

.gradient-gold-bg .ae-content .white-panel img.__pfs+div.__pfs p.__pfs,div.__pfs#tour-packages .item-container .item div.__pfs h3.__pfs,div.__pfs#tour-packages .item-container .item div.__pfs p.__pfs {
    text-align: left
}

div.__pfs#tour-packages .item-container .item div.__pfs a.__pfs {
    margin-top: auto;
    text-align: left!important;
    display: block;
    font-size: 16px
}

div.__pfs#flight-pass .item-container {
    display: flex;
    flex-direction: column;
    margin: 0 15px
}

div.__pfs#flight-pass .item-container .item {
    box-shadow: 0 0 15px -3px rgb(0 0 0/20%);
    display: flex;
    background: #fff
}

div.__pfs#flight-pass .item-container .item div.__pfs {
    padding: 0 25px 15px
}

div.__pfs#flight-pass .item-container .item .fp-image {
    background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/sun-hub/fp.jpg)no-repeat center center;
    background-size: cover;
    padding: 0;
    width: 100%;
    min-width: 400px;
    min-height: 240px
}

div.__pfs#flight-pass .item-container .item div.__pfs a.__pfs,div.__pfs#flight-pass .item-container .item div.__pfs p.__pfs {
    text-align: left;
    font-size: 16px
}

div.__pfs#hub-tabs {
    margin: 25px 0 0
}

div.__pfs#travel-perks .item-container {
    display: flex;
    flex-wrap: wrap
}

div.__pfs#travel-perks .item-container+p.__pfs {
    margin-left: 15px
}

div.__pfs#travel-perks .item-container .item {
    margin: 15px;
    flex: calc(33.33% - 30px);
    display: flex;
    flex-direction: column;
    align-content: center;
    text-align: center;
    box-shadow: 0 6px 19px -7px rgb(0 0 0/20%)
}

div.__pfs#travel-perks .item-container .item div.__pfs {
    padding: 0 30px 20px
}

.cabin-container .item p.__pfs:last-child,.gradient-gold-bg .ae-content .white-panel img.__pfs+div.__pfs p.__pfs:last-child,div.__pfs#travel-perks .item-container .item p.__pfs:last-child {
    margin-top: auto
}

div.__pfs#travel-perks .item-container .item img.__pfs {
    width: 100%;
    height: 200px;
    margin: 0 auto
}

div.__pfs#travel-perks .item-container .item a.__pfs {
    font-size: 16px;
    margin-top: auto
}

div.__pfs#cabins {
    padding-top: 6em
}

.cabin-container {
    display: flex
}

.cabin-container .item {
    flex: 1;
    display: flex;
    flex-direction: column
}

.cabin-container .item:nth-of-type(2) {
    margin: 0 50px
}

.cabin-container .item ul.__pfs li.__pfs {
    margin-bottom: 7px;
    font-size: 16px
}

.cabin-container .item a.__pfs,.sun-hub h2.__pfs+p.__pfs+p.__pfs,.usa-hub h2.__pfs+p.__pfs+p.__pfs {
    font-size: 16px
}

.cabin-container+p.__pfs {
    text-align: center;
    margin: 40px auto 20px
}

div.__pfs#mll {
    text-align: center;
    padding-top: 4em
}

div.__pfs#mll .ae-carousel {
    margin: 30px auto 0;
    padding: 0 20px;
    background: #fff
}

.destination-container {
    display: flex;
    flex-wrap: wrap;
    background: 0 0;
    padding: 20px 40px
}

.destination-container .item {
    flex: calc(25% - 80px);
    text-align: center;
    margin: 10px;
    box-shadow: 0 0 15px -3px rgba(0,0,0,.2)
}

#destination-tabContent .destination-container .item {
    width: 22%;
    flex: inherit
}

#destination-tabContent .destination-container {
    justify-content: center;
    background: 0 0
}

#northernCanada .destination-container .item {
    width: 25%;
    margin: 10px auto
}

.destination-container .item div.__pfs {
    padding: 15px;
    background: #fff
}

.destination-container .item:hover {
    box-shadow: 0 0 15px -3px rgb(0 0 0/50%);
    cursor: pointer
}

.sun-hub div.__pfs.gradient-clouds-bg,.sun-hub h2.__pfs.gradient-clouds-bg,.usa-hub div.__pfs.gradient-clouds-bg,.usa-hub h2.__pfs.gradient-clouds-bg {
    padding: 50px 0 6em;
    width: 100%
}

.sun-hub div.__pfs.gradient-clouds-bg+.ae-content,.sun-hub h2.__pfs.gradient-clouds-bg+.ae-content,.usa-hub div.__pfs.gradient-clouds-bg+.ae-content,.usa-hub h2.__pfs.gradient-clouds-bg+.ae-content {
    margin-top: -13em
}

.sun-hub div.__pfs#all-destinations div.__pfs.gradient-clouds-bg+.ae-content,.usa-hub div.__pfs#all-destinations div.__pfs.gradient-clouds-bg+.ae-content {
    margin-top: -10em
}

div.__pfs#earn-bonus-points .row {
    display: flex;
    margin: 0 0 30px
}

div.__pfs.tc-panel-content {
    max-width: 1200px;
    width: 100%;
    margin: 0 auto;
    background: #fff
}

[data-testid="disclaimer"] {
    margin-bottom: 40px;
}

.InteractiveMap.init-hidden {
    visibility: hidden;
    height: 0;
    width: 0;
}

.InteractiveMap.init {
    display: none;
}

.InteractiveMap.active {
    display: block !important;
    visibility: visible !important;
}

div.__pfs#all-destinations .ae-content,div.__pfs#companion .ae-content {
    padding-bottom: 0;
    text-align: center;
}

.destination-container .item img.__pfs {
    object-fit: cover;
    height: 170px
}

.destination-container+.backToTop {
    margin-bottom: 3em
}

.mobile-content,div.__pfs#family-travel h2.__pfs:after,div.__pfs#vacation-packages h2.__pfs:after {
    display: none
}

div.__pfs#destination-tabContent {
    margin-top: 5px
}

@media only screen and (min-width:1201px) {
    .sun-hub .ae-content,.usa-hub .ae-content {
        width: 1200px;
        margin: 0 auto
    }

    div.__pfs#hub-tabs .nav.nav-tabs {
        width: 1200px;
        max-width: calc(100% - 40px);
        margin: auto;
        border-bottom: none;
        justify-content: center
    }

    div.__pfs#tc-panel-container-companion,div.__pfs#tc-panel-container-companion+.tc-panel-content,div.__pfs#tc-panel-container-fp,div.__pfs#tc-panel-container-fp+.tc-panel-content,div.__pfs#tc-panel-container-seat,div.__pfs#tc-panel-container-seat+.tc-panel-content,div.__pfs.tc-panel-container,div.__pfs.tc-panel-container+.tc-panel-content {
        margin: 0 auto 10px;
        width: calc(1200px - 8em)!important;
        max-width: 1200px
    }

    div.__pfs.tc-panel-container {
        margin-top: 4em!important
    }

    div.__pfs#travel-perks .ae-content.gradient-grey-bg {
        padding: 0 12em;
        width: 100%;
        max-width: 100%
    }
}

@media only screen and (max-width:1201px) and (min-width:1025px) {
    .module-row.module-row--campaign_widget+.container {
        width: 100%;
        max-width: calc(100% - 100px)
    }

    .sun-hub .header-row,.usa-hub .header-row {
        justify-content: end
    }

    div.__pfs.tc-panel-container,div.__pfs.tc-panel-container+.tc-panel-content {
        width: calc(100% - 12em)!important
    }

    div.__pfs.tc-panel-container {
        margin-top: 4em!important
    }

    div.__pfs#earn-bonus-points p.__pfs.grey-bg {
        margin: 20px auto 0
    }

    .module-row.module-row--price_widget {
        padding: 0 30px
    }
}

@media only screen and (max-width:1200px) and (min-width:768px) {
    .sun-hub .sun-promo-box .sections:nth-of-type(2) {
        flex-wrap: wrap
    }

    .sun-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs:last-child {
        flex-basis: 100%;
        padding: 20px 0
    }

    .sun-hub .sun-promo-box .ntp-tooltip button.block-align.copy-code.primary-btn {
        width: fit-content;
        max-width: 255px
    }

    .sun-hub .nav.nav-tabs,.usa-hub .nav.nav-tabs {
        width: calc(100% - 60px);
        max-width: 100%;
        margin: 0 auto
    }

    .sun-hub .nav.nav-tabs + .tab-content,
    .usa-hub .nav.nav-tabs + .tab-content {
        margin: 0 auto;
        width: 100%;
    }

    div.__pfs#advance-seat-selection .row img.__pfs.col-50 {
        max-width: 600px;
        margin: 0 auto 20px
    }

    div.__pfs#earn-bonus-points div.__pfs.row .col-50 .item {
        width: 70%;
        padding-left: 35%
    }

    div.__pfs#earn-bonus-points div.__pfs.row .col-50.white-panel {
        margin-top: 3em
    }

    div.__pfs#flight-pass .item-container,div.__pfs#tour-packages .item-container {
        margin: 0 30px
    }

    div.__pfs#tour-packages .item-container .item {
        max-width: 100%;
        margin: 20px 0
    }

    div.__pfs#flight-pass {
        margin-top: 0
    }

    div.__pfs.tc-panel-content {
        margin: 0 auto;
        max-width: calc(100% - 60px)
    }

    div.__pfs#tc-panel-container-fp,div.__pfs#tc-panel-container-fp+.tc-panel-content {
        margin: 0 auto;
        max-width: calc(100% - 100px)
    }

    div.__pfs#tc-panel-container-seat,div.__pfs#tc-panel-container-seat+.tc-panel-content {
        margin: 0 auto;
        max-width: calc(100% - 30px)
    }

    .destination-container .item img.__pfs,div.__pfs#travel-perks .item-container .item img.__pfs {
        height: 140px
    }

    div.__pfs#flight-pass .item-container .item .fp-image {
        min-height: 260px;
        width: 300%
    }

    div.__pfs#flight-pass .item-container .item div.__pfs {
        display: flex;
        flex-direction: column
    }

    div.__pfs#flight-pass .item-container .item div.__pfs a.__pfs {
        margin-top: auto
    }

    div.__pfs#tc-panel-container-companion,div.__pfs#tc-panel-container-companion+.tc-panel-content {
        max-width: 100%
    }

    div.__pfs#travel-perks .ae-content.gradient-grey-bg {
        padding: 0 2em;
        width: 100%;
        max-width: 100%
    }

    .sun-hub ul.__pfs.slick-dots {
        margin: 10px auto
    }
}

@media only screen and (min-width:1025px) {
    .sun-hub .header-row,.usa-hub .header-row {
        height: 500px
    }

    div.__pfs#hub-tabs {
        padding-top: 110px
    }

    :lang(fr) div.__pfs#hub-tabs {
        padding-top: 140px
    }

    .sun-hub .ae-content.top,.usa-hub .ae-content.top {
        margin-top: -200px
    }

    .sun-hub .ae-content.top .module-row.module-row--price_widget .container,.sun-hub .nav.nav-tabs li.__pfs img.__pfs,.usa-hub .ae-content.top .module-row.module-row--price_widget .container,.usa-hub .nav.nav-tabs li.__pfs img.__pfs {
        max-width: 100%
    }

    .InteractiveMap {
        margin: 0-30px
    }

    .sun-hub .nav.nav-tabs,.usa-hub .nav.nav-tabs {
        display: flex
    }

    .sun-hub .nav.nav-tabs li.__pfs,.usa-hub .nav.nav-tabs li.__pfs {
        flex: 25%;
        border: 0
    }

    .sun-hub .nav.nav-tabs li.__pfs a.__pfs {
        border-bottom: solid 4px transparent
    }

    .sun-hub .nav.nav-tabs li.__pfs.active a.__pfs,.sun-hub .nav.nav-tabs li.__pfs:hover a.__pfs {
        border: 0;
        border-bottom: solid 4px #005078;
        box-shadow: 0 12px 15px -4px rgba(0,0,0,.2)
    }

    .sun-hub #offer-tabs .nav.nav-tabs li.__pfs.active a.__pfs,.sun-hub #offer-tabs .nav.nav-tabs li.__pfs:hover a.__pfs {
        border: 0;
        border-bottom: solid 4px #005078;
        box-shadow: none
    }

    div.__pfs#destination-tabs .nav.nav-tabs li.__pfs.tab a.__pfs {
        height: inherit;
        background: 0 0;
        box-shadow: none;
        margin: 0
    }

    div.__pfs#destination-tabs .nav.nav-tabs li.__pfs:not(.active) a.__pfs {
        border-bottom: 1px solid gray
    }

    div.__pfs#destination-tabs .nav.nav-tabs li.__pfs:hover a.__pfs {
        border-bottom: solid 4px #005078;
        box-shadow: none;
        background: 0 0!important
    }

    div.__pfs#destination-tabs {
        margin-top: 3em
    }

    div.__pfs#destination-tabs .nav.nav-tabs li.__pfs {
        flex: none;
        width: 25%
    }
}

@media only screen and (max-width:1024px) and (min-width:768px) {
    .sun-hub .ae-content#top,.usa-hub .ae-content#top {
        margin-bottom: -80px
    }

    .sun-hub .header-row .hero-image {
        padding-left: 2em;
        height: 350px
    }

    .usa-hub .header-row .hero-image {
        padding-left: 2em;
        width: 100%;
        height: 350px
    }

    .sun-hub .header-row .hero-image {
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/sun-hub/hero-sun-tablet.png)no-repeat center center;
        background-size: cover;
        width: 100%!important
    }

    div.__pfs#hub-tabs {
        margin-top: 6.5em!important
    }

    div.__pfs#top-offers .gradient-clouds-bg+.ae-content {
        padding: 0 10px 4em
    }

    div.__pfs#join-aeroplan {
        padding: 20px;
        margin: 0 0 30px 30px;
        background: #f9f9f9
    }

    div.__pfs#earn-bonus-points div.__pfs.row .col-50.white-panel {
        margin-top: 0
    }

    div.__pfs#earn-bonus-points .ae-content {
        padding: 4em 15px
    }

    div.__pfs#earn-bonus-points p.__pfs.grey-bg {
        margin-left: 0
    }

    .destination-container {
        display: flex!important;
        flex-wrap: wrap!important;
        background: #fff
    }

    div.__pfs#earn-bonus-points div.__pfs.row .col-50 .item {
        width: 100%;
        padding-left: 0
    }

    div.__pfs#join-aeroplan form .form-control {
        background: #fff
    }

    .sun-hub .grey-bg .ae-content p.__pfs:first-child,.usa-hub .grey-bg .ae-content p.__pfs:first-child {
        border-left: none
    }

    .sun-hub .grey-bg .ae-content p.__pfs:last-child,.usa-hub .grey-bg .ae-content p.__pfs:last-child {
        border-right: none
    }

    .sun-hub .grey-bg .ae-content,.usa-hub .grey-bg .ae-content {
        padding: 0
    }

    .blue-bg .ae-content {
        padding: 0;
        width: 100%
    }

    .sun-hub .nav.nav-tabs,.usa-hub .nav.nav-tabs {
        display: flex
    }

    .sun-hub .nav.nav-tabs li.__pfs,.usa-hub .nav.nav-tabs li.__pfs {
        flex: 25%
    }

    .sun-hub .nav.nav-tabs li.__pfs img.__pfs,.usa-hub .nav.nav-tabs li.__pfs img.__pfs {
        max-width: 100%
    }

    .blue-bg .tab-content {
        padding: 4em 30px
    }

    .module-row.module-row--campaign_widget+.container {
        width: 100%;
        max-width: calc(100% + 40px)
    }

    div.__pfs#flight-pass .ae-content .white-panel {
        padding: 30px 10px
    }

    #tour-packages .tile div.__pfs:last-child {
        padding: 0 20px 20px
    }

    div.__pfs#tour-packages .ae-content {
        padding: 4em 0
    }

    div.__pfs#tour-packages .item-container {
        margin: 30px;
        flex-direction: column
    }

    div.__pfs#tour-packages .item-container .item {
        max-width: 50%;
        flex-direction: column;
        margin: 0 auto 20px
    }

    div.__pfs#tour-packages .item-container .item img.__pfs,div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50,div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50.white-panel {
        width: 100%
    }

    div.__pfs#companion .row.box.white-panel .ntp-tooltip {
        width: 70%
    }

    div.__pfs#companion .row.box.white-panel .ntp-tooltip button.block-align.copy-code,div.__pfs.vertical-config#earn-bonus-points {
        flex-direction: column
    }

    .sun-hub .promoSection .promo-container {
        flex-direction: column;
        text-align: center;
        justify-content: center
    }

    .sun-hub .promoSection.gradient-blue-bg .promo-container {
        flex-direction: column-reverse;
        text-align: center;
        justify-content: center
    }

    .sun-hub .promoSection .promo-container div.__pfs+img.__pfs,.sun-hub .promoSection .promo-container img.__pfs+div.__pfs {
        padding: 2em
    }

    div.__pfs#travel-perks .item-container {
        flex: calc(50% - 40px);
        margin: 10px
    }

    div.__pfs#travel-perks .item-container .item div.__pfs {
        padding: 0 15px 20px
    }

    div.__pfs#travel-perks .item-container+p.__pfs {
        margin-left: 10px
    }

    .sun-hub .promoSection .promo-container img.__pfs {
        max-width: 525px;
        margin: 0 auto;
        width: 100%
    }

    .sun-hub .promoSection .promo-container div.__pfs&gt;* {
        text-align: center
    }

    .sun-hub .promoSection .promo-container div.__pfs h2.__pfs:after {
        margin: 20px auto
    }

    div.__pfs#advance-seat-selection .row,div.__pfs#earn-bonus-points .row {
        flex-direction: row
    }

    div.__pfs.vertical-config#earn-bonus-points p.__pfs.grey-bg {
        margin: 10px auto!important;
        width: 100%
    }

    div.__pfs#tc-panel-container-seat,div.__pfs#tc-panel-container-seat+.tc-panel-content {
        width: calc(100% - 180px)
    }

    div.__pfs#travel-perks .item-container .item {
        width: calc(50% - 30px);
        flex: calc(50% - 30px)
    }

    div.__pfs#travel-perks .item-container .item img.__pfs {
        height: 215px
    }

    div.__pfs.tc-panel-container,div.__pfs.tc-panel-container+.tc-panel-content {
        width: calc(100% - 60px)!important
    }

    .sun-hub h3.__pfs,.usa-hub h3.__pfs {
        font: 600 16px Open Sans
    }
}

@media only screen and (max-width:767px) {
    div.__pfs#hub-tabs {
        margin: 0
    }

    .sun-hub h1.__pfs,.usa-hub h1.__pfs {
        font-size: 32px;
        line-height: 1.12;
        margin-bottom: 10px
    }

    .sun-hub h2.__pfs,.usa-hub h2.__pfs {
        font-size: 24px;
        line-height: 1.12;
        margin-bottom: 12px;
        width: 95%;
        padding: 20px 0 0
    }

    .sun-hub .h2.__pfs-like,.usa-hub .h2.__pfs-like {
        font-size: 24px;
        margin: 25px auto;
        width: 95%
    }

    .sun-hub h3.__pfs,.usa-hub h3.__pfs {
        font-size: 16px;
        font-weight: 700
    }

    .sun-hub p.__pfs,.sun-hub ul.__pfs li.__pfs,.usa-hub p.__pfs,.usa-hub ul.__pfs li.__pfs {
        font-size: 14px!important
    }

    a.__pfs.backTop {
        margin-top: 4em
    }

    .sun-hub .sun-promo-box .sections:nth-of-type(2) {
        flex-direction: column
    }

    .sun-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs {
        padding: 10px 0
    }

    .sun-hub .sun-promo-box {
        padding: 20px 20px 0
    }

    .sun-hub .ae-content,.usa-hub .ae-content {
        padding: 2em 0
    }

    .sun-hub .ae-content.top,.usa-hub .ae-content.top {
        margin-top: -8em;
        padding: 20px 0
    }

    .sun-hub .header-row,.usa-hub .header-row {
        background: 0 0;
        height: auto
    }

    .sun-hub .header-row .hero-image {
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/sun-hub/hero-sun-mobile.png)no-repeat center center;
        background-size: cover;
        width: 100%!important;
        margin: 0
    }

    .sun-hub .ae-content#top,.usa-hub .ae-content#top {
        margin-top: -80px
    }

    div.__pfs#travel-perks .ae-content {
        padding: 0!important
    }

    .destination-container {
        width: 100%;
        padding: 0 20px 20px;
        background: #fff!important
    }

    .destination-container .slick-dots {
        bottom: 0
    }

    .destination-container .slick-dots li.__pfs:nth-child(n+6) {
        display: none
    }

    .destination-container .item {
        width: calc(100% - 30px)!important;
        flex: none;
        background: #fff;
        margin: 15px
    }

    #destination-tabContent .destination-container {
        justify-content: center
    }

    div.__pfs#top-offers .gradient-clouds-bg+.ae-content {
        margin-top: -12em
    }

    .destination-container .item img.__pfs {
        height: auto
    }

    .sun-hub div.__pfs.gradient-clouds-bg+.ae-content,.sun-hub h2.__pfs.gradient-clouds-bg+.ae-content,.usa-hub div.__pfs.gradient-clouds-bg+.ae-content,.usa-hub h2.__pfs.gradient-clouds-bg+.ae-content {
        margin-top: -6em
    }

    #destination-tabContent .destination-container .item,div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50,div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50.white-panel {
        width: 100%
    }

    div.__pfs.vertical-config#earn-bonus-points p.__pfs.grey-bg {
        margin: 10px auto!important;
        width: 100%
    }

    .cabin-container,div.__pfs#earn-bonus-points .row,div.__pfs#top-offers .item-container,div.__pfs#travel-perks .item-container,div.__pfs.vertical-config#earn-bonus-points,div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50 .item-container {
        flex-direction: column
    }

    div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50 .item-container .item {
        flex-direction: row
    }

    div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50 .item-container .item .desc p.__pfs {
        text-align: left
    }

    div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50 .item-container .item .desc p.__pfs:first-child {
        font-size: 20px!important
    }

    div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50 .item-container .item:last-child {
        border-left: none
    }

    div.__pfs.vertical-config#earn-bonus-points div.__pfs.row .col-50 .item-container .item .desc p.__pfs span.__pfs.blue {
        display: initial
    }

    .cabin-container .item,.cabin-container .item:nth-of-type(2) {
        margin: 20px
    }

    div.__pfs#top-offers .item-container .item {
        padding: 20px
    }

    div.__pfs#mll {
        margin: 0 20px
    }

    .covid-box {
        margin: 3em 20px 0
    }

    .sun-hub button.slick-next,.sun-hub button.slick-next:hover,.sun-hub button.slick-prev,.sun-hub button.slick-prev:hover,.usa-hub button.slick-next,.usa-hub button.slick-next:hover,.usa-hub button.slick-prev,.usa-hub button.slick-prev:hover {
        display: block!important;
        background: url(https://www.aircanada.com/content/dam/aircanada/loyalty-content/images/prev-arrow.svg)!important;
        background-size: 20px!important;
        top: 35%
    }

    .sun-hub button.slick-next,.sun-hub button.slick-next:hover,.usa-hub button.slick-next,.usa-hub button.slick-next:hover {
        transform: rotate(180deg)
    }

    div.__pfs#earn-bonus-points div.__pfs.row .col-50 {
        width: calc(100% - 30px)!important;
        margin: 10px auto!important
    }

    div.__pfs#earn-bonus-points div.__pfs.row .col-50 .item {
        margin: 12.5px auto;
        flex-direction: row;
        width: 85%
    }

    div.__pfs#earn-bonus-points div.__pfs.row .col-50 .item&gt;* {
        text-align: left
    }

    div.__pfs#earn-bonus-points .tc-panel-container {
        margin: 20px 15px 0;
        width: calc(100% - 30px)
    }

    div.__pfs#tc-panel-container-companion,div.__pfs#tc-panel-container-seat,div.__pfs.tc-panel-content {
        width: calc(100% - 30px)
    }

    div.__pfs#advance-seat-selection .row img.__pfs.col-50 {
        max-width: 400px;
        margin: 0 auto 10px
    }

    div.__pfs#advance-seat-selection .row .col-50.white-panel {
        margin: 20px auto;
        width: calc(100% - 60px)
    }

    div.__pfs#tour-packages .item-container {
        margin: 30px;
        flex-direction: column
    }

    div.__pfs#tour-packages .item-container .item {
        max-width: 100%;
        margin: 0 0 20px;
        flex-direction: column
    }

    div.__pfs#companion .row.box.white-panel .ntp-tooltip,div.__pfs#tour-packages .item-container .item img.__pfs {
        width: 100%
    }

    div.__pfs#flight-pass {
        margin-top: 0
    }

    div.__pfs#flight-pass .item-container {
        margin: 30px
    }

    div.__pfs#flight-pass .item-container .item {
        flex-direction: column
    }

    div.__pfs#flight-pass .item-container .item .fp-image {
        height: 200px
    }

    div.__pfs#tc-panel-container-fp,div.__pfs#tc-panel-container-fp+.tc-panel-content {
        width: calc(100% - 100px);
        margin: 0 auto
    }

    div.__pfs#mll .ae-carousel {
        margin-bottom: 15px
    }

    div.__pfs#mll .ae-carousel ul.__pfs.slick-dots {
        bottom: -10px;
        position: relative
    }

    #tour-packages .tile,div.__pfs#flight-pass .ae-content .description,section#aeroplan-offer .ae-row {
        flex-direction: column
    }

    div.__pfs#join-aeroplan {
        margin: 30px 0;
        text-align: left;
        padding: 10px 20px 0
    }

    div.__pfs#join-aeroplan,div.__pfs#join-aeroplan form .form-control {
        background: #f9f9f9
    }

    .sun-hub .grey-bg .ae-content p.__pfs:first-child,.usa-hub .grey-bg .ae-content p.__pfs:first-child {
        border-left: none
    }

    .sun-hub .grey-bg .ae-content p.__pfs:last-child,.usa-hub .grey-bg .ae-content p.__pfs:last-child {
        border-right: none
    }

    .sun-hub .grey-bg .ae-content,.usa-hub .grey-bg .ae-content {
        padding: 0
    }

    .sun-hub .nav.nav-tabs li.__pfs.active a.__pfs:after,.sun-hub .nav.nav-tabs li.__pfs.active:after,.usa-hub .nav.nav-tabs li.__pfs.active a.__pfs:after,.usa-hub .nav.nav-tabs li.__pfs.active:after {
        display: none
    }

    .blue-bg .ae-content nav .nav-tabs li.__pfs a.__pfs,.sun-hub .promoSection .promo-container div.__pfs&gt;* {
        text-align: center
    }

    .blue-bg .ae-content nav .nav-tabs li.__pfs.active a.__pfs {
        color: #000
    }

    .blue-bg .ae-content {
        width: 100%;
        padding: 0
    }

    .sun-hub .nav.nav-tabs,.usa-hub .nav.nav-tabs {
        display: flex;
        flex-wrap: wrap
    }

    .sun-hub .nav.nav-tabs li.__pfs,.usa-hub .nav.nav-tabs li.__pfs {
        flex: 50%
    }

    .blue-bg .tab-content {
        padding: 30px
    }

    .blue-bg .tab-content h3.__pfs+p.__pfs,.blue-bg .tab-content img.__pfs+p.__pfs {
        width: 90%;
        margin: 0 auto 2em
    }

    .module-row.module-row--campaign_widget+.container {
        width: 100%;
        max-width: calc(100% + 40px)
    }

    div.__pfs#flight-pass .ae-content .description div.__pfs {
        text-align: left;
        margin-bottom: 20px
    }

    div.__pfs#flight-pass .ae-content .description div.__pfs img.__pfs {
        margin: 0 20px;
        float: left;
        width: 85px;
        height: 85px
    }

    div.__pfs#flight-pass .ae-content .white-panel {
        padding: 0 20px;
        flex-direction: column
    }

    div.__pfs#flight-pass .ae-content .white-panel div.__pfs {
        padding: 20px 0;
        border-top: 1px solid #e6e6e6
    }

    .sun-hub .nav.nav-tabs li.__pfs img.__pfs,.sun-hub .promoSection .promo-container img.__pfs,.usa-hub .nav.nav-tabs li.__pfs img.__pfs {
        max-width: 100%
    }

    .sun-hub p.__pfs.mobile-content,.usa-hub p.__pfs.mobile-content {
        display: flex;
        align-items: center;
        justify-content: space-between;
        font-weight: 700!important;
        font-size: 16px!important;
        border-top: 1px solid #c8c8c8;
        padding: 15px;
        box-shadow: 0 3px 10px -3px rgba(0,0,0,.2);
        width: 100%;
        margin: 0 auto;
        text-align: center
    }

    div.__pfs#destination-tabs .nav.nav-tabs.is-open li.__pfs.active,div.__pfs#destination-tabs .nav.nav-tabs.is-open li.__pfs:hover,div.__pfs#destination-tabs .nav.nav-tabs.is-open ul.__pfs li.__pfs:active,div.__pfs#hub-tabs .nav.nav-tabs.is-open li.__pfs.active,div.__pfs#hub-tabs .nav.nav-tabs.is-open li.__pfs:hover,div.__pfs#hub-tabs .nav.nav-tabs.is-open ul.__pfs li.__pfs:active,div.__pfs#offer-tabs .nav.nav-tabs.is-open li.__pfs.active,div.__pfs#offer-tabs .nav.nav-tabs.is-open li.__pfs:hover,div.__pfs#offer-tabs .nav.nav-tabs.is-open ul.__pfs li.__pfs:active,p.__pfs.mobile-content:hover {
        cursor: pointer
    }

    p.__pfs.mobile-content span.__pfs.dropdown {
        background: url(https://www.aircanada.com/content/dam/aircanada/loyalty-content/images/icon/chevron-down.svg)no-repeat center center;
        background-size: 10px 10px;
        display: block;
        width: 24px;
        height: 24px;
        -o-object-fit: contain;
        object-fit: contain;
        margin-left: 8px
    }

    .mobile-content.rotate span.__pfs.dropdown {
        transform: rotateZ(180deg)
    }

    div.__pfs#destination-tabs .nav.nav-tabs,div.__pfs#hub-tabs .nav.nav-tabs,div.__pfs#hub-tabs .nav.nav-tabs.is-open li.__pfs.active a.__pfs:after,div.__pfs#offer-tabs .nav.nav-tabs,div.__pfs#offer-tabs .nav.nav-tabs.is-open li.__pfs.active a.__pfs:after div.__pfs#destination-tabs .nav.nav-tabs.is-open li.__pfs.active a.__pfs:after {
        display: none
    }

    div.__pfs#hub-tabs .nav.nav-tabs.is-open,div.__pfs#offer-tabs .nav.nav-tabs.is-open div.__pfs#destination-tabs .nav.nav-tabs.is-open {
        display: block;
        flex-direction: column;
        width: calc(100% + 30px);
        margin: 0 auto;
        position: absolute;
        z-index: 10;
        background: #fff
    }

    div.__pfs#hub-tabs .nav.nav-tabs.is-open li.__pfs,div.__pfs#offer-tabs .nav.nav-tabs.is-open li.__pfs div.__pfs#destination-tabs .nav.nav-tabs.is-open li.__pfs {
        display: flex;
        font-size: 16px;
        width: 100%
    }

    div.__pfs#hub-tabs .nav.nav-tabs.is-open li.__pfs a.__pfs,div.__pfs#offer-tabs .nav.nav-tabs.is-open li.__pfs a.__pfs div.__pfs#destination-tabs .nav.nav-tabs.is-open li.__pfs a.__pfs {
        display: flex;
        flex-direction: row;
        padding: 15px;
        justify-content: flex-start;
        align-items: center;
        border-bottom: none;
        text-align: left;
        box-shadow: none;
        width: 100%;
        font-size: 14px;
        color: #000
    }

    div.__pfs#hub-tabs .nav.nav-tabs.is-open li.__pfs a.__pfs img.__pfs,div.__pfs#offer-tabs .nav.nav-tabs.is-open li.__pfs a.__pfs img.__pfs div.__pfs#destination-tabs .nav.nav-tabs.is-open li.__pfs a.__pfs img.__pfs {
        margin: 0 10px 0 0;
        width: 20px;
        height: 20px
    }

    div.__pfs#earn-bonus-points p.__pfs.grey-bg {
        margin: 0 auto 40px
    }

    div.__pfs#companion .row.box.white-panel div.__pfs.col-33 {
        height: 300px
    }

    .light-blue-bg,div.__pfs#companion .row.box.white-panel {
        width: 100%;
        flex-direction: column
    }

    div.__pfs#companion .row.box.white-panel .row.promotional-code p.__pfs:first-child+p.__pfs,div.__pfs#companion .row.box.white-panel .row.promotional-code p.__pfs:first-child+ul.__pfs {
        padding-left: 45px;
        margin-top: -10px
    }

    .sun-hub .promoSection .promo-container {
        flex-direction: column;
        text-align: center;
        justify-content: center;
        max-width: 500px
    }

    .sun-hub .promoSection .promo-container div.__pfs h2.__pfs:after {
        margin: 20px auto
    }

    .sun-hub .promoSection.gradient-blue-bg .promo-container {
        flex-direction: column-reverse;
        text-align: center;
        justify-content: center
    }

    .sun-hub .promoSection .promo-container div.__pfs+img.__pfs,.sun-hub .promoSection .promo-container img.__pfs+div.__pfs {
        padding: 15px
    }

    div.__pfs#travel-perks .item-container {
        flex: calc(50% - 40px);
        margin: 10px
    }

    div.__pfs#travel-perks .item-container .item div.__pfs {
        padding: 0 15px 20px
    }

    div.__pfs#travel-perks .item-container+p.__pfs {
        margin-left: 10px
    }

    div.__pfs#travel-perks .item-container .item {
        margin: 15px auto;
        max-width: 400px
    }

    .sun-hub .promoSection.gradient-blue-bg .promo-container div.__pfs {
        padding-right: 0
    }

    div.__pfs#flight-pass .item-container .item .fp-image {
        min-width: 0
    }

    div.__pfs.tc-panel-container,div.__pfs.tc-panel-container+.tc-panel-content {
        width: calc(100% - 60px)!important
    }
}

@media only screen and (max-width:767px) and (min-width:415px) {
    .sun-hub .header-row .hero-image,.usa-hub .header-row .hero-image {
        height: 300px!important
    }
}

@media only screen and (max-width:414px) {
    .sun-hub .header-row .hero-image,.usa-hub .header-row .hero-image {
        height: 250px!important
    }

    div.__pfs#family-travel {
        padding-bottom: 10em
    }

    div.__pfs#family-travel .ae-content img.__pfs.col-60 {
        width: 277px;
        height: 165px;
        align-self: flex-start;
        margin: 5em 0 0
    }
}

.primary-btn,.secondary-btn {
    font-size: 16px!important
}

.europe-hub,.sun-hub,.usa-hub {
    width: 100%;
    max-width: 100%;
    overflow: hidden
}

#offers .gradient-blue-bg #top-offers .ae-content {
    padding-top: 30px;
    padding-bottom: 0
}

#offers .gradient-blue-bg .ae-content .white-panel {
    display: flex;
    padding: 20px;
    margin: 10px auto;
    width: calc(100% - 24em);
    /* height: fit-content */
}

.promo-full p.__pfs {
    font-size: 16px
}

#offers .gradient-blue-bg .ae-content .white-panel p.__pfs.divider,p.__pfs.divider {
    flex: none;
    width: 1px;
    height: 30px;
    background-color: #979797
}

#offers #top-offers .ae-content .white-panel {
    display: block;
    margin-top: -60px;
    width: calc(100% - 24em);
    position: relative;
    z-index: 2;
    text-align: center;
    box-shadow: 0-8px 10px -4px #d3d3d3
}

#offers #top-offers .ae-content .white-panel .red-pill {
    color: #fff;
    margin: 10px auto
}

p.__pfs.booking-mask-popup.btn-book-now.blue {
    color: #005078
}

@media only screen and (min-width:768px) {
    div.__pfs#offer-tabs .nav.nav-tabs {
        display: flex;
        justify-content: center
    }

    div.__pfs#offer-tabs .nav.nav-tabs li.__pfs {
        flex: 0 0 25%;
        width: 25%
    }
}

div.__pfs#offer-tabContent .tab-pane {
    /* padding: 30px 0; */
    padding: 30px 0 0 0;
    margin: 0 auto;
    text-align: center
}

div.__pfs#offer-tabContent .tab-pane .secondary-btn {
    padding: 15px 45px;
    margin: 30px auto
}

div.__pfs#flightOffers {
    background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/sun-hub/faded-faregrid-bg.jpg)no-repeat bottom center;
    background-size: contain
}

div.__pfs#flightOffers .ae-content+img.__pfs {
    width: 100%;
    margin-top: -35%;
    object-fit: cover;
    height: 500px;
    z-index: 1;
    opacity: .7
}

div.__pfs#flightOffers .ae-content {
    position: relative;
    z-index: 5;
    padding-top: 0
}

#offers .gradient-blue-bg#acv .promo-container .white-panel {
    padding: 0;
    display: flex;
    flex-direction: column;
    position: relative
}

#offers .gradient-blue-bg#acv .promo-container .promo-2col {
    display: flex;
    margin: 0 auto
}

#offers .gradient-blue-bg#acv .promo-container .promo-2col .white-panel {
    flex: 50%;
    width: 50%;
    margin: 10px 0
}

#offers .gradient-blue-bg#acv .promo-container .promo-2col .white-panel:last-child {
    margin-left: 20px
}

.promo-full .primary-btn {
    width: fit-content
}

.promo-full {
    background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/sun-hub/sunhub-aug2023-with-gradient.jpg)no-repeat center center;
    background-size: cover;
    min-height: 210px;
    margin: 10px auto;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    text-align: left
}

.promo-full div.__pfs {
    width: 48%;
    padding: 10px
}

.gradient-gold-bg .ae-content .white-panel {
    padding: 0;
    display: flex;
    flex-direction: column;
    flex: 1
}

.gradient-gold-bg .ae-content .white-panel img.__pfs {
    width: 100%;
    height: 206px;
    object-fit: cover
}

.gradient-gold-bg .ae-content .white-panel img.__pfs+div.__pfs {
    padding: 20px;
    display: flex;
    flex-direction: column;
    height: 100%
}

div.__pfs#all-destinations .ae-content a.__pfs {
    font-weight: 600;
    margin: 10px auto;

}

div.__pfs#all-destinations .ae-content p.__pfs,div.__pfs#all-destinations .ae-content p.__pfs a.__pfs {
    text-align: center
}

div.__pfs#all-destinations .ae-content p.__pfs a.__pfs {
    font-size: 14px;
    text-decoration: underline
}

div.__pfs#spotlight-destinations .white-panel {
    padding: 0;
    display: flex
}

div.__pfs#spotlight-destinations .white-panel img.__pfs {
    flex: 40%;
    width: 40%;
    min-width: 450px;
}

div.__pfs#spotlight-destinations .white-panel img.__pfs:last-child {
    flex: none;
    width: auto;
    min-width: auto;
    height: 145px;
    margin: 20px 0;
    object-fit: contain;
}

div.__pfs#spotlight-destinations .white-panel div.__pfs&gt;* {
    text-align: left
}

div.__pfs#spotlight-destinations .white-panel div.__pfs a.__pfs,div.__pfs#spotlight-destinations .white-panel div.__pfs p.__pfs {
    font-size: 16px
}

div.__pfs#destination-tabs li.__pfs a.__pfs,div.__pfs#spotlight-destinations .white-panel a.__pfs {
    font-weight: 600
}

#perks h2.__pfs+p.__pfs {
    margin: 10px auto 20px
}

div.__pfs#travel-perks .white-panel {
    display: flex;
    align-items: center;
    padding: 40px 20px;
    justify-content: space-evenly;
    margin: 4em auto 0
}

div.__pfs#travel-perks .white-panel div.__pfs:not(.divider) {
    flex: 1;
    padding: 0 20px;
    align-self: baseline
}

div.__pfs#travel-perks .white-panel div.__pfs.divider {
    height: 40px;
    width: 1px;
    flex: none;
    background-color: #d0d0ce
}

div.__pfs#travel-perks .white-panel div.__pfs img.__pfs {
    width: 75px;
    height: 75px;
    margin: 0 auto 15px
}

div.__pfs#travel-perks .white-panel p.__pfs {
    margin-bottom: 0
}

div.__pfs#family-travel {
    background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/sun-hub/bg-airport.png)no-repeat bottom right;
    background-size: cover
}

div.__pfs#family-travel .ae-content {
    display: flex
}

div.__pfs#family-travel .ae-content img.__pfs.col-60 {
    width: 392px;
    height: 234px;
    align-self: flex-end;
    margin-left: 4em
}

div.__pfs#family-travel h2.__pfs,div.__pfs#family-travel p.__pfs,div.__pfs#vacation-packages h2.__pfs,div.__pfs#vacation-packages p.__pfs {
    text-align: left;
    width: 100%
}

div.__pfs#family-travel p.__pfs,div.__pfs#vacation-packages p.__pfs {
    font-size: 16px
}

div.__pfs#family-travel a.__pfs,div.__pfs#vacation-packages a.__pfs {
    font-weight: 600;
    text-decoration: underline;
    font-size: 16px
}

div.__pfs#vacation-packages {
    background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/sun-hub/bg-beach.png)no-repeat bottom left;
    background-size: contain
}

@media only screen and (min-width:1600px) {
    div.__pfs#vacation-packages {
        background-size: contain;
        padding-bottom: 6em;
        padding-top: 6em
    }

    div.__pfs#family-travel {
        background: #f1f7fa url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/sun-hub/bg-airport.png)no-repeat bottom right;
        background-size: contain
    }

    div.__pfs#family-travel .ae-content img.__pfs.col-60 {
        margin-left: auto
    }
}

div.__pfs#vacation-packages .ae-content {
    justify-content: end;
    display: flex;
    align-content: center;
    padding: 0;
    width: 100%
}

div.__pfs#vacation-packages .ae-content .col-40 {
    padding: 30px;
    display: block;
    width: 55%;
    margin-bottom: 6em
}

div.__pfs#vacation-promise .ae-content {
    padding: 4em 12em;
    text-align: center
}

div.__pfs#vacation-promise .ae-content .panel-container {
    display: flex;
    justify-content: space-evenly;
    margin: 4em auto 2em
}

div.__pfs#vacation-promise .ae-content .panel-container div.__pfs {
    flex: 1
}

div.__pfs#vacation-promise .ae-content .panel-container div.__pfs img.__pfs {
    width: 110px;
    height: 110px;
    margin: 0 auto 15px
}

div.__pfs#vacation-promise .ae-content .panel-container div.__pfs p.__pfs {
    font-size: 14px;
    text-align: center
}

div.__pfs#vacation-promise .promo-full {
    width: 100%;
    margin-top: 4em
}

#offers .gradient-blue-bg#acv .promo-container {
    padding: 0 12em
}

.gradient-gold-bg .ae-content {
    padding: 4em 4em 0
}

@media only screen and (max-width:1024px) and (min-width:768px) {
    div.__pfs#vacation-packages {
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/sun-hub/bg-beach-tablet.png)no-repeat bottom left;
        background-size: contain
    }

    div.__pfs#vacation-packages .ae-content {
        justify-content: start
    }

    div.__pfs#family-travel {
        background: #f1f7fa url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/sun-hub/bg-airport-tablet.png)no-repeat top right;
        background-size: contain
    }

    #sun-hub .ae-content {
        padding: 4em 0
    }

    #offers #top-offers .ae-content .white-panel,#offers .gradient-blue-bg .ae-content .white-panel,div.__pfs#offer-tabs .nav.nav-tabs {
        width: calc(100% - 40px)
    }

    div.__pfs#offer-tabs .nav.nav-tabs li.__pfs {
        flex: 0 0 50%;
        width: 50%
    }

    .module-row.module-row--price_widget {
        padding: 0 20px
    }

    #offers .gradient-blue-bg#acv .promo-container {
        padding: 0
    }

    .ae-content .ae-carousel-tablet {
        background: 0 0
    }

    .gradient-gold-bg .ae-content .white-panel {
        margin: 0;
        background: 0 0
    }

    .gradient-gold-bg .ae-content .slick-slide div.__pfs:first-child:not(.white-panel) {
        margin: 10px auto;
        width: 60%
    }

    button.slick-next:before,button.slick-prev:before {
        display: none
    }

    div.__pfs#destination-tabs .nav.nav-tabs li.__pfs.tab:not(.active) a.__pfs,div.__pfs#hub-tabs .nav.nav-tabs li.__pfs.tab:not(.active) a.__pfs,div.__pfs#offer-tabs .nav.nav-tabs li.__pfs.tab:not(.active) a.__pfs {
        border-bottom: 1px solid #d0d0ce
    }

    div.__pfs#family-travel .ae-content,div.__pfs#spotlight-destinations .white-panel {
        flex-direction: column
    }

    div.__pfs#spotlight-destinations .white-panel img.__pfs {
        flex: 100%;
        width: 100%;
        height: 242px;
        object-fit: cover
    }

    div.__pfs#travel-perks .white-panel div.__pfs:not(.divider) {
        flex: 1;
        padding: 0 30px;
        align-self: self-start
    }

    div.__pfs#family-travel .ae-content .col-40,div.__pfs#family-travel .ae-content .col-60 {
        width: 100%
    }

    div.__pfs#family-travel .ae-content img.__pfs.col-60 {
        align-self: flex-start;
        margin-left: 12em
    }

    div.__pfs#vacation-packages .ae-content .col-40 {
        width: 70%
    }

    div.__pfs#vacation-promise .ae-content {
        padding: 4em 0
    }

    div.__pfs#vacation-promise .ae-content .panel-container {
        flex-wrap: wrap;
        margin: 4em auto
    }

    div.__pfs#vacation-promise .ae-content .panel-container div.__pfs {
        flex: 50%
    }
}

@media only screen and (max-width:767px) {
    div.__pfs#vacation-packages {
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/sun-hub/bg-beach-mobile.png)no-repeat bottom left;
        background-size: contain;
        padding-bottom: 10em
    }

    div.__pfs#spotlight-destinations .white-panel {
        flex-direction: column
    }

    div.__pfs#family-travel {
        background: #f1f7fa url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/sun-hub/bg-airport-mobile.png)no-repeat;
        padding-bottom: 16em;
        background-position: right bottom;
        background-size: 101%
    }

    #offers .gradient-blue-bg .ae-content .white-panel {
        width: 100%
    }

    div.__pfs#flightOffers {
        background-size: cover
    }

    div.__pfs#spotlight-destinations .white-panel img.__pfs {
        flex: 100%;
        width: 100%;
        height: 242px;
        object-fit: cover;
        min-width: 350px;
    }

    #offers .gradient-blue-bg:not(#acv) .ae-content .white-panel:not(.sale-panel) {
        background: 0 0;
        box-shadow: none;
        flex-direction: column;
        padding: 20px 0
    }

    #offers .gradient-blue-bg:not(#acv) .ae-content .white-panel p.__pfs:not(.red-pill) {
        background: #fff;
        box-shadow: 0 6px 32px -19px rgb(0 0 0/30%),0 7px 16px -8px rgb(0 0 0/10%);
        padding: 20px;
        margin: 10px
    }

    #offers #top-offers .ae-content .white-panel p.__pfs {
        margin: 0 auto 10px;
        box-shadow: none!important;
        width: 100%
    }

    #offers .gradient-blue-bg:not(#acv) .ae-content .white-panel p.__pfs.divider {
        display: none
    }

    #offers #top-offers .ae-content .white-panel {
        width: calc(100% - 40px);
        background: #fff
    }

    #offers #top-offers .ae-content .white-panel .red-pill {
        color: #fff;
        margin: 10px auto;
        padding: 5px 15px;
        box-shadow: none;
        background: #f01428;
        width: -webkit-fit-content;
        width: -moz-fit-content;
        width: fit-content
    }

    div.__pfs#offer-tabs .nav.nav-tabs li.__pfs {
        flex: 0 0 50%;
        width: 50%
    }

    .module-row.module-row--price_widget {
        padding: 0 20px
    }

    #offers .gradient-blue-bg#acv .promo-container {
        padding: 0
    }

    .ae-content .ae-carousel-tablet {
        background: 0 0
    }

    .gradient-gold-bg .ae-content .white-panel {
        margin: 0;
        background: 0 0
    }

    .gradient-gold-bg .ae-content .slick-slide div.__pfs:first-child:not(.white-panel) {
        margin: 10px auto;
        width: 60%
    }

    button.slick-next:before,button.slick-prev:before {
        display: none
    }

    #offers .gradient-blue-bg#acv .promo-container .promo-2col {
        flex-direction: column
    }

    #offers .gradient-blue-bg#acv .promo-container .promo-2col .white-panel {
        flex: 100%;
        width: 100%
    }

    #offers .gradient-blue-bg#acv .promo-container .promo-2col .white-panel:last-child {
        margin-left: 0
    }

    .promo-full div.__pfs {
        width: 100%;
        padding: 20px;
        background: #fff;
        margin-top: 178px
    }

    div.__pfs#travel-perks .white-panel {
        flex-direction: column;
        width: 60%;
        margin-bottom: 40px
    }

    div.__pfs#travel-perks .white-panel div.__pfs.divider {
        width: 40px;
        height: 1px;
        margin: 40px auto;
        flex: none;
        background-color: #d0d0ce
    }

    div.__pfs#family-travel .ae-content img.__pfs.col-60 {
        width: 330px;
        height: 219px;
        align-self: flex-start;
        margin: 17em 0 0
    }

    div.__pfs#vacation-promise .promo-full {
        box-shadow: 0 0 10px -3px rgb(0 0 0/20%)
    }

    div.__pfs#family-travel .ae-content,div.__pfs#vacation-packages .ae-content,div.__pfs#vacation-promise .ae-content .panel-container {
        flex-direction: column
    }

    div.__pfs#vacation-packages .ae-content .col-40 {
        padding: 30px;
        display: block;
        width: 100%;
        margin-bottom: 6em
    }

    div.__pfs#travel-perks .white-panel div.__pfs:not(.divider) {
        width: 100%
    }

    .sun-hub p.__pfs.mobile-content.topLayer img.__pfs {
        width: 31px;
        height: 31px
    }

    .sun-hub p.__pfs.mobile-content.topLayer span.__pfs:not(.dropdown) {
        flex: none;
        margin-right: auto;
        margin-left: 15px
    }

    #offers .gradient-blue-bg #top-offers .ae-content {
        width: 100%
    }

    div.__pfs#destination-tabs .mobile-content {
        background: #fff;
        margin-top: 3em
    }
}

/* SUN promo banner linked to special offers tile */
div.__pfs.sunSale {
    display: none;
}
div.__pfs.sunSale .white-panel {
    display: flex;
    border-radius: 14px;
    width: 100%;
    max-width: 100%;
    overflow: hidden;
    gap: 30px;
    box-shadow: 0px 0px 15px -3px rgba(0, 0, 0, 0.2);
    -webkit-box-shadow: 0px 0px 15px -3px rgba(0, 0, 0, 0.2);
}

@media only screen and (max-width: 1024px) {
    div.__pfs.sunSale .white-panel {
        flex-direction: column;
    }
    div.__pfs.sunSale .white-panel img {
        max-width: 100%;
    }
}

div.__pfs.sunSale .white-panel img {
    border-radius: 14px;
    max-width: 350px;
    width: 100%;
}

div.__pfs.sunSale.__bss {
    width: 100%;
    max-width: 100%;
}

div.__pfs.sunSale.__bss .ae-content {
    max-width: 1220px;
    width: 100% !important;
    padding: 10px;
}

div.__pfs.sunSale .white-panel div {
    display: flex;
    flex-direction: column;
    flex: 1;
}

div.__pfs.sunSale .white-panel div h2 {
    margin: 0 0 10px !important;
    padding: 0 !important;
    text-align: left !important;
    width: 100%;
}

div.__pfs.sunSale .white-panel div h2+p {
    font-size: 14px !important;
    line-height: 20px;
    margin: 0 !important;
    width: 100% !important;
    text-align: left !important;
    margin-bottom: 10px;
}

div.__pfs.sunSale .white-panel div&gt;* {
    text-align: left;
}

div.__pfs.sunSale .white-panel div .primary-btn {
    background-color: #005078 !important;
    color: #fff !important;
    border: none;
    cursor: pointer;
    margin: auto 0 0 auto;
    text-align: center;
    padding: 15px 60px;
    text-decoration: none;
    border-radius: 14px;
    font-size: 14px !important;
    display: block;
}

@media only screen and (max-width: 1024px) {
    div.__pfs.sunSale .white-panel div .primary-btn {
        margin: 20px auto 0;
    }
}

.__pill, .__pfs.red-pill.__bss, .__pfs.black-pill.__bss {
    color: #fff !important;
    font-size: 14px !important;
    font-weight: bold !important;
    margin: 0 0 10px;
    padding: 5px 15px;
    font-size: 14px;
    font-weight: bold;
    box-shadow: none;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content
}

.__pill.red, .__pfs.red-pill.__bss {
    background: #f01428;
}

.__pill.black, .__pfs.black-pill.__bss {
    background: #000;
}</pre></body></html>