/*.Campaign.lg\:max-w-6xl.self-center {
    width: 100%;
    max-width: 100%;
    margin: 0;
    padding: 0
}

.px-3,.py-4 {
    padding: 0
}*/

.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.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[data-test='disclaimer'] a.__pfs {
    font-weight: 700;
    text-decoration: none;
}

@media only screen and (max-width: 1024px) {
    .Campaign .__pfs.row.__bss {margin: 0;}
}

:lang(en) .europe-hub .ae-content#top :lang(fr) .usa-hub .ae-content#top,:lang(fr) .europe-hub .ae-content#top {
    margin-bottom: -100px
}

.error-check p.__pfs.__bss {
    color: #d8292f;
    font-size: 14px!important
}

.europe-hub h1.__pfs,.europe-hub h1.__pfs.__bss,.usa-hub h1.__pfs,.usa-hub h1.__pfs.__bss {
    font: 300 36px Open Sans;
    margin: 30px auto
}

:lang(fr) .europe-hub h1.__pfs,:lang(fr) .europe-hub h1.__pfs.__bss,:lang(fr) .usa-hub h1.__pfs,:lang(fr) .usa-hub h1.__pfs.__bss {
    font: 300 33px Open Sans;
    margin: 30px auto
}

.europe-hub h2.__pfs,.europe-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%
}

.europe-hub h2.__pfs.__bss:after,.europe-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
}

.europe-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
}

.europe-hub h3.__pfs,.europe-hub h3.__pfs.__bss,.usa-hub h3.__pfs,.usa-hub h3.__pfs.__bss {
    font: 600 20px Open Sans
}

.europe-hub p.__pfs.__bss,.europe-hub ul.__pfs li.__pfs.__bss,.usa-hub p.__pfs.__bss,.usa-hub ul.__pfs li.__pfs.__bss {
    font: 14px Open Sans
}

.europe-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
}

.europe-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs p.__pfs.__bss:first-child span.__pfs,.europe-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
}

.europe-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs p.__pfs.__bss:first-child span.__pfs img.__pfs,.europe-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs p.__pfs:first-child span.__pfs img.__pfs {
    width: 25px;
    height: auto
}

.europe-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs p.__pfs.__bss {
    font-size: 14px
}

.europe-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs p.__pfs.__bss:first-child+div.__pfs,.europe-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs p.__pfs.__bss:first-child+p.__pfs,.europe-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs p.__pfs:first-child+div.__pfs,.europe-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs p.__pfs:first-child+p.__pfs {
    padding-left: 48px
}

.europe-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
}

.europe-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,div.__pfs#join-aeroplan h3.__pfs.__bss,div.__pfs#join-aeroplan p.__pfs.__bss {
    text-align: left
}

section#aeroplan-offer .ae-row .col-66 h2.__pfs,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,div.__pfs#join-aeroplan h3.__pfs.__bss {
    margin: 10px 0
}

div.__pfs#join-aeroplan form {
    margin: 25px 0 15px
}

label#rules-check {
    display: block;
    overflow: hidden;
    padding-left: 10px;
    font-weight: 400!important
}

label#rules-check a.__pfs,label#rules-check a.__pfs.__bss {
    font-weight: 600!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
}

.europe-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
}

.europe-hub .grey-bg .ae-content p.__pfs a.__pfs,.europe-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.__bss {
    padding: 0 20px;
    text-align: CENTER
}

.europe-hub .grey-bg .ae-content p.__pfs a.__pfs img.__pfs,.europe-hub .grey-bg .ae-content p.__pfs.__bss a.__pfs.__bss 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.__bss img.__pfs {
    display: block;
    text-align: center;
    margin: 0 auto 10px;
    height: 24px
}

.europe-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 a.__pfs,.blue-bg .ae-content nav .nav-tabs li.__pfs.__bss a.__pfs.__bss {
    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.__bss.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.__bss.active a.__pfs.__bss,.blue-bg .ae-content nav .nav-tabs li.__pfs.active a.__pfs {
    border-top: solid 3px #005078
}

.blue-bg .ae-content nav .nav-tabs li.__pfs a.__pfs span.__pfs,.blue-bg .ae-content nav .nav-tabs li.__pfs.__bss a.__pfs.__bss 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
}

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/europe-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,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 .row.promotional-code p.__pfs.__bss:first-child+ul.__pfs li.__pfs.__bss: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)
}

div.__pfs#companion a.__pfs.primary-btn.booking-mask-popup {
    margin: 35px auto
}

#tour-packages .tile a.__pfs,#tour-packages .tile a.__pfs.__bss {
    text-decoration: underline
}

div.__pfs#euro-tabs .nav.nav-tabs.__pfs.__bss li.__pfs.__bss.tab a.__pfs.__bss {
    display: flex;
    flex-direction: column;
    font-weight: 400;
    align-items: center;
    padding: 10px;
    height: 100%;
    font-size: 20px;
    box-shadow: 0 9px 12px -3px rgba(0,0,0,.12)
}

div.__pfs#euro-tabs .nav.nav-tabs.__pfs.__bss li.__pfs.__bss.tab.active a.__pfs.__bss {
    font-weight: 600
}

div.__pfs#euro-tabs .nav.nav-tabs li.__pfs.tab a.__pfs img.__pfs,div.__pfs#euro-tabs .nav.nav-tabs.__pfs.__bss li.__pfs.__bss.tab a.__pfs.__bss img.__pfs {
    width: 20px;
    margin-bottom: 10px
}

div.__pfs#euro-tabs .nav.nav-tabs.__pfs.__bss li.__pfs.__bss.tab:hover a.__pfs.__bss {
    background: #fff
}

.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;
    margin-top: 20px;
}

div.__pfs#top-offers .item-container .item p.__pfs.__bss:last-child {
    margin: auto auto 0;
    font-size: 16px
}

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: #005078;
    font-size: 36px;
    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,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.__bss.grey-bg img.__pfs,div.__pfs#earn-bonus-points p.__pfs.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,div.__pfs#advance-seat-selection .row .col-50.white-panel p.__pfs.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 .item-container .item div.__pfs h3.__pfs.__bss {
    text-align: left;
    margin: 20px 0 10px;
}

div.__pfs#tour-packages .item-container .item div.__pfs a.__pfs,div.__pfs#tour-packages .item-container .item div.__pfs a.__pfs.__bss {
    margin-top: auto;
    text-align: left!important;
    display: block;
    font-size: 16px
}

div.__pfs#advance-seat-selection .row .col-50.white-panel p.__pfs.__bss,div.__pfs#flight-pass .item-container .item div.__pfs a.__pfs.__bss,div.__pfs#flight-pass .item-container .item div.__pfs p.__pfs.__bss,div.__pfs#tour-packages .item-container .item div.__pfs p.__pfs.__bss {
    text-align: left;
    font-size: 16px
}

.cabin-container .item p.__pfs.__bss:last-child,div.__pfs#flight-pass .ae-content .white-panel div.__pfs a.__pfs: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,div.__pfs#travel-perks .item-container .item ul.__pfs li.__pfs.__bss {
    text-align: left;
    font-size: 16px;
    margin-bottom: 7px
}

div.__pfs#travel-perks .item-container .item a.__pfs,div.__pfs#travel-perks .item-container .item a.__pfs.__bss {
    font-size: 16px;
    margin-top: auto
}

.cabin-container .item ul.__pfs li.__pfs,.cabin-container .item ul.__pfs li.__pfs.__bss {
    margin-bottom: 7px
}

.cabin-container .item a.__pfs,.cabin-container .item a.__pfs.__bss,.cabin-container .item ul.__pfs li.__pfs,.cabin-container .item ul.__pfs li.__pfs.__bss,.europe-hub h2.__pfs+p.__pfs+p.__pfs,.europe-hub h2.__pfs.__bss+p.__pfs+p.__pfs,.usa-hub h2.__pfs+p.__pfs+p.__pfs,.usa-hub h2.__pfs.__bss+p.__pfs+p.__pfs,div.__pfs#tour-packages .item-container .item div.__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
}

.destination-container .item div.__pfs p.__pfs+p.__pfs,.destination-container .item div.__pfs p.__pfs.__bss+p.__pfs {
    font-size: 14px
}

.europe-hub h2.__pfs.__bss.gradient-clouds-bg,.usa-hub h2.__pfs.__bss.gradient-clouds-bg {
    padding: 50px 0 6em;
    width: 100%
}

.europe-hub h2.__pfs.__bss.gradient-clouds-bg+.ae-content,.usa-hub h2.__pfs.__bss.gradient-clouds-bg+.ae-content {
    margin-top: -13em
}

@media only screen and (min-width:1201px) {
    .europe-hub .ae-content,.usa-hub .ae-content {
        width: 1200px;
        margin: 0 auto
    }

    div.__pfs#euro-tabs .nav.nav-tabs.__pfs.__bss {
        width: 1200px;
        max-width: calc(100% - 40px);
        margin: auto
    }

    .europe-hub .header-row .hero-image,.usa-hub .header-row .hero-image {
        width: 1200px!important;
        padding-left: 0!important;
        margin: 0 auto 10em
    }

    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 {
        margin: 0 auto;
        width: calc(1200px - 16em);
        max-width: 1200px
    }

    div.__pfs.tc-panel-container {
        margin-top: 4em!important
    }
}

@media only screen and (max-width:1201px) and (min-width:1025px) {
    /*.Campaign.lg\:max-w-6xl.self-center,.module-row.module-row--campaign_widget+.container {
        width: 100%;
        max-width: calc(100% - 100px)
    }*/

    .europe-hub .header-row,.usa-hub .header-row {
        justify-content: end
    }

    .europe-hub .header-row .hero-image,.usa-hub .header-row .hero-image {
        margin: 0 auto 10em
    }

    div.__pfs.tc-panel-container {
        margin-top: 4em!important
    }
}

@media only screen and (max-width:1200px) and (min-width:768px) {
    .europe-hub .sun-promo-box .sections:nth-of-type(2) {
        flex-wrap: wrap
    }

    .europe-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs:last-child {
        flex-basis: 100%;
        padding: 20px 0
    }

    .europe-hub .sun-promo-box .ntp-tooltip button.block-align.copy-code.primary-btn {
        width: fit-content;
        max-width: 255px
    }

    .europe-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,div.__pfs#earn-bonus-points .row {
        flex-direction: column
    }

    div.__pfs#advance-seat-selection .row .col-50,div.__pfs#earn-bonus-points div.__pfs.row .col-50,div.__pfs#earn-bonus-points div.__pfs.row .col-50.white-panel {
        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#tour-packages .item-container {
        margin: 0 30px;
        flex-direction: column
    }

    div.__pfs#tour-packages .item-container .item {
        max-width: 100%;
        margin: 20px 0
    }

    div.__pfs#flight-pass {
        margin-top: 0
    }

    div.__pfs#flight-pass .item-container {
        margin: 0 30px
    }

    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 {
        height: 140px
    }

    div.__pfs#flight-pass .item-container .item .fp-image {
        height: 350px;
        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.__bss {
        margin-top: auto
    }

    div.__pfs#tc-panel-container-companion,div.__pfs#tc-panel-container-companion+.tc-panel-content {
        max-width: 100%
    }
}

@media only screen and (min-width:1025px) {
    .europe-hub .header-row,.usa-hub .header-row {
        height: 500px
    }

    div.__pfs#euro-tabs {
        padding-top: 50px
    }

    :lang(fr) div.__pfs#euro-tabs {
        padding-top: 80px
    }

    .europe-hub .header-row .hero-image,.usa-hub .header-row .hero-image {
        padding-left: 2em;
        width: 100%;
        height: 350px
    }

    .europe-hub .ae-content.top,.usa-hub .ae-content.top {
        margin-top: -200px
    }

    .europe-hub .ae-content.top .module-row.module-row--price_widget .container,.europe-hub .nav.nav-tabs.__pfs.__bss li.__pfs.__bss img.__pfs,.usa-hub .ae-content.top .module-row.module-row--price_widget .container,.usa-hub .nav.nav-tabs.__pfs.__bss li.__pfs.__bss img.__pfs {
        max-width: 100%
    }

    .InteractiveMap {
        margin: 0-30px
    }

    .europe-hub .nav.nav-tabs.__pfs.__bss,.usa-hub .nav.nav-tabs.__pfs.__bss {
        display: flex
    }

    .europe-hub .nav.nav-tabs.__pfs.__bss li.__pfs.__bss,.usa-hub .nav.nav-tabs.__pfs.__bss li.__pfs.__bss {
        flex: 25%
    }
}

@media only screen and (max-width:1024px) and (min-width:768px) {
    .europe-hub .ae-content#top,.usa-hub .ae-content#top {
        margin-bottom: -80px
    }

    .europe-hub .header-row .hero-image,.usa-hub .header-row .hero-image {
        padding-left: 2em;
        width: 100%;
        height: 350px
    }

    .europe-hub .header-row {
        height: 350px;
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/hero-euroHub-tablet.jpg)no-repeat center center
    }

    .europe-hub.may .header-row {
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/euro-hub-may.jpg)no-repeat center center;
        background-size: cover
    }

    .europe-hub.august .header-row {
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/hero-europe-sale-tablet.png)no-repeat center center;
        background-size: cover
    }

    .europe-hub.april .header-row {
        height: 350px;
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/hero-euroHub-tablet-april.jpg)no-repeat center center
    }

    .europe-hub.seatSale .header-row {
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/hero-euroHub-tablet-seatSale.jpg)no-repeat center center
    }

    .europe-hub.seatSale.v2 .header-row {
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/hero-euroHub-tablet-seatSale-april.jpg)no-repeat center center
    }

    .InteractiveMap.active {
        padding: 0 20px;
    }

    div.__pfs#euro-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 .ae-content {
        padding: 4em 15px
    }

    div.__pfs#earn-bonus-points p.__pfs.__bss.grey-bg {
        margin-left: 20%
    }

    .destination-container {
        display: flex!important;
        flex-wrap: wrap!important;
        background: #fff
    }

    div.__pfs#earn-bonus-points div.__pfs.row .col-50 .item {
        width: 80%;
        padding-left: 20%
    }

    div.__pfs#join-aeroplan form .form-control {
        background: #fff
    }

    .europe-hub .grey-bg .ae-content p.__pfs.__bss:first-child,.usa-hub .grey-bg .ae-content p.__pfs.__bss:first-child {
        border-left: none
    }

    .europe-hub .grey-bg .ae-content p.__pfs.__bss:last-child,.usa-hub .grey-bg .ae-content p.__pfs.__bss:last-child {
        border-right: none
    }

    .europe-hub .grey-bg .ae-content,.usa-hub .grey-bg .ae-content {
        padding: 0
    }

    .blue-bg .ae-content {
        padding: 0;
        width: 100%
    }

    .europe-hub .nav.nav-tabs.__pfs.__bss,.usa-hub .nav.nav-tabs.__pfs.__bss {
        display: flex
    }

    .europe-hub .nav.nav-tabs.__pfs.__bss li.__pfs.__bss,.usa-hub .nav.nav-tabs.__pfs.__bss li.__pfs.__bss {
        flex: 25%
    }

    .europe-hub .nav.nav-tabs.__pfs.__bss li.__pfs.__bss img.__pfs,.usa-hub .nav.nav-tabs.__pfs.__bss li.__pfs.__bss img.__pfs {
        max-width: 100%
    }

    .blue-bg .tab-content {
        padding: 4em 30px
    }

    /*.Campaign.lg\:max-w-6xl.self-center,.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#companion .row.box.white-panel .ntp-tooltip {
        width: 70%
    }

    div.__pfs#companion .row.box.white-panel .ntp-tooltip button.block-align.copy-code {
        flex-direction: column
    }
}

@media only screen and (max-width:767px) {
    div.__pfs#euro-tabs {
        margin: 20%0 0
    }

    .europe-hub h1.__pfs.__bss,.usa-hub h1.__pfs.__bss {
        font-size: 32px;
        line-height: 1.12;
        margin-bottom: 10px
    }

    .europe-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
    }

    .europe-hub .h2.__pfs-like,.usa-hub .h2.__pfs-like {
        font-size: 24px;
        margin: 25px auto;
        width: 95%
    }

    .europe-hub h3.__pfs.__bss,.usa-hub h3.__pfs.__bss {
        font-size: 16px;
        font-weight: 700
    }

    .europe-hub p.__pfs.__bss,.europe-hub ul.__pfs li.__pfs.__bss,.usa-hub p.__pfs.__bss,.usa-hub ul.__pfs li.__pfs.__bss {
        font-size: 14px!important
    }

    .europe-hub p.__pfs.mobile-content span.__pfs:nth-of-type(1), .usa-hub p.__pfs.mobile-content span.__pfs:nth-of-type(1) {
        margin-right: auto;
        margin-left: 10px;
    }

    a.__pfs.backTop {
        margin-top: 4em
    }

    .europe-hub .sun-promo-box .sections:nth-of-type(2) {
        flex-direction: column
    }

    .europe-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs {
        padding: 10px 0
    }

    .europe-hub .sun-promo-box {
        padding: 20px 20px 0
    }

    .europe-hub .ae-content,.usa-hub .ae-content {
        padding: 2em 0
    }

    .europe-hub .ae-content.top,.usa-hub .ae-content.top {
        margin-top: -8em;
        padding: 20px 0
    }

    .europe-hub .header-row .hero-image {
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/hero-euroHub-mobile.jpg)no-repeat center center;
        background-size: cover;
        margin: 0
    }

    .europe-hub.may .header-row .hero-image {
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/euro-hub-may-mobile.jpg)no-repeat center center;
        background-size: cover;
        margin: 0
    }

    .europe-hub.august .header-row .hero-image {
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/hero-europe-sale-mobile.png)no-repeat center center;
        background-size: cover;
        margin: 0;
        display: none;
    }

    .europe-hub.april .header-row .hero-image {
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/hero-euroHub-mobile-april.jpg)no-repeat center center;
        background-size: cover;
        margin: 0
    }

    .europe-hub.seatSale .header-row .hero-image {
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/hero-euroHub-mobile-seatSale.jpg)no-repeat center center;
        background-size: cover
    }

    .europe-hub.seatSale.v2 .header-row .hero-image {
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/hero-europe-v2.jpg)no-repeat center center;
        background-size: cover
    }

    .europe-hub .ae-content#top,.usa-hub .ae-content#top {
        margin-bottom: 0;
        margin-top: 200px;
        padding: 0 15px
    }

    .europe-hub .ae-content#top h1.__pfs.__bss {
        font-size: 28px
    }

    div.__pfs#travel-perks .ae-content {
        padding: 0
    }

    .destination-container {
        width: 100%;
        padding: 0 20px 20px;
        background: #fff!important
    }

    .destination-container .slick-dots {
        bottom: 0
    }

    .destination-container .slick-dots li.__pfs.__bss:nth-child(n+6) {
        display: none
    }

    .destination-container .item {
        width: calc(100% - 30px)!important;
        flex: none;
        background: #fff;
        margin: 15px
    }

    div.__pfs#top-offers .gradient-clouds-bg+.ae-content {
        margin-top: -12em
    }

    .destination-container .item img.__pfs {
        height: auto
    }

    .europe-hub div.__pfs.gradient-clouds-bg+.ae-content,.europe-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
    }

    .cabin-container,div.__pfs#earn-bonus-points .row,div.__pfs#earn-bonus-points div.__pfs.row .col-50 .item,div.__pfs#top-offers .item-container,div.__pfs#travel-perks .item-container {
        flex-direction: column
    }

    .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
    }

    .europe-hub button.slick-next,.europe-hub button.slick-next:hover,.europe-hub button.slick-prev,.europe-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%
    }

    .europe-hub button.slick-next,.europe-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
    }

    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-container,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
    }

    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
    }

    .europe-hub .grey-bg .ae-content p.__pfs.__bss:first-child,.usa-hub .grey-bg .ae-content p.__pfs.__bss:first-child {
        border-left: none
    }

    .europe-hub .grey-bg .ae-content p.__pfs.__bss:last-child,.usa-hub .grey-bg .ae-content p.__pfs.__bss:last-child {
        border-right: none
    }

    .europe-hub .grey-bg .ae-content,.usa-hub .grey-bg .ae-content {
        padding: 0
    }

    .europe-hub .nav.nav-tabs.__pfs.__bss li.__pfs.__bss.active a.__pfs:after,.europe-hub .nav.nav-tabs.__pfs.__bss li.__pfs.__bss.active:after,.usa-hub .nav.nav-tabs.__pfs.__bss li.__pfs.__bss.active a.__pfs:after,.usa-hub .nav.nav-tabs.__pfs.__bss li.__pfs.__bss.active:after,div.__pfs#euro-tabs .nav.nav-tabs.__pfs.__bss,div.__pfs#euro-tabs .nav.nav-tabs.__pfs.__bss.is-open li.__pfs.__bss.active a.__pfs:after {
        display: none
    }

    .blue-bg .ae-content nav .nav-tabs li.__pfs.__bss a.__pfs.__bss {
        text-align: center
    }

    .blue-bg .ae-content nav .nav-tabs li.__pfs.__bss.active a.__pfs.__bss {
        color: #000
    }

    .blue-bg .ae-content {
        width: 100%;
        padding: 0
    }

    .europe-hub .nav.nav-tabs.__pfs.__bss,.usa-hub .nav.nav-tabs.__pfs.__bss {
        display: flex;
        flex-wrap: wrap
    }

    .europe-hub .nav.nav-tabs.__pfs.__bss li.__pfs.__bss,.usa-hub .nav.nav-tabs.__pfs.__bss li.__pfs.__bss {
        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
    }

    /*.Campaign.lg\:max-w-6xl.self-center,.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
    }

    .europe-hub .nav.nav-tabs.__pfs.__bss li.__pfs.__bss img.__pfs,.usa-hub .nav.nav-tabs.__pfs.__bss li.__pfs.__bss img.__pfs {
        max-width: 100%
    }

    .europe-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#euro-tabs .nav.nav-tabs.__pfs.__bss.is-open li.__pfs.__bss.active,div.__pfs#euro-tabs .nav.nav-tabs.__pfs.__bss.is-open li.__pfs.__bss:hover,div.__pfs#euro-tabs .nav.nav-tabs.__pfs.__bss.is-open ul.__pfs li.__pfs.__bss: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#euro-tabs .nav.nav-tabs.__pfs.__bss.is-open {
        display: block;
        flex-direction: column;
        width: 100%;
        margin: 0 auto;
        position: absolute;
        z-index: 10;
        background: #fff;
        top: 55px;
        padding: 0;
        box-shadow: 0 3px 10px -3px rgb(0 0 0 / 20%);
    }

    div.__pfs#euro-tabs .nav.nav-tabs.__pfs.__bss.is-open li.__pfs.__bss {
        display: flex;
        font-size: 16px;
        width: 100%
    }

    div.__pfs#euro-tabs .nav.nav-tabs.__pfs.__bss.is-open li.__pfs.__bss span.__pfs {font-size: 16px;}

    div.__pfs#euro-tabs .nav.nav-tabs.__pfs.__bss.is-open li.__pfs.__bss a.__pfs.__bss {
        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#euro-tabs .nav.nav-tabs.__pfs.__bss.is-open li.__pfs.__bss a.__pfs.__bss img.__pfs {
        margin: 0 10px 0 0;
        width: 17px
    }

    div.__pfs#earn-bonus-points p.__pfs.__bss.grey-bg {
        margin-bottom: 40px
    }

    div.__pfs#companion .row.box.white-panel div.__pfs.col-33 {
        height: 300px
    }

    div.__pfs#companion .row.box.white-panel div.__pfs.col-33 .red-pill {
        margin: 5px
    }

    .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
    }
}

@media only screen and (max-width:767px) and (min-width:415px) {
    .europe-hub .header-row .hero-image,.usa-hub .header-row .hero-image {
        height: 350px
    }
}

@media only screen and (max-width:414px) {
    .europe-hub .header-row .hero-image,.usa-hub .header-row .hero-image {
        height: 250px
    }
}

.europe-hub .header-row,.usa-hub .header-row {
    width: 100%;
    max-width: 100%;
    display: flex;
    justify-content: end;
    flex-direction: column
}

.usa-hub .header-row {
    background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/hero-usa.jpg)no-repeat center center;
    background-size: cover
}

.europe-hub .header-row {
    background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/hero-euroHub.jpg)no-repeat center center;
    background-size: cover
}

.europe-hub.may .header-row {
    background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/hero-europe-sale.jpg)no-repeat center center;
    background-size: cover
}

.europe-hub.august .header-row {
    background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/hero-europe-sale.jpg)no-repeat top center;
    background-size: cover
}

.europe-hub.april .header-row {
    background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/hero-euroHub-april.jpg)no-repeat center center;
    background-size: cover
}

.europe-hub.seatSale .header-row {
    background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/hero-euroHub-seatSale.jpg)no-repeat center center;
    background-size: cover
}

.europe-hub.seatSale.v2 .header-row {
    background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/hero-europe-v2.jpg)no-repeat center center;
    background-size: cover
}

.europe-hub .ae-content#top,.usa-hub .ae-content#top {
    background-color: #fff;
    text-align: center;
    position: relative;
    z-index: 2;
    padding: 0 30px;
    margin-bottom: -60px
}

.europe-hub .ae-content,.usa-hub .ae-content {
    text-align: left;
    margin: 0 auto
}

.europe-hub .ae-content a.__pfs:hover:not(.primary-btn),.usa-hub .ae-content a.__pfs:hover:not(.primary-btn) {
    text-decoration: underline!important
}

.europe-hub .header-row .hero-image,.usa-hub .header-row .hero-image {
    max-width: 100%;
    margin: 0 0 10em
}

p.__pfs.booking-mask-popup, .__pfs.__bss.booking-mask-popup,
p.__pfs.__bss.booking-mask-popup a.__pfs.__bss {
    color: #005078;
    font-weight: 600!important;
    cursor: pointer;
    margin: 30px auto;
    width: fit-content;
}

.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,#f1f7fa 110%)
}

.gradient-grey-bg {
    background: linear-gradient(to top,#fff,#f9f9f9);
    margin-top: 3em
}

.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
}

.europe-hub .h2.__pfs-like,.usa-hub .h2.__pfs-like {
    text-align: center;
    font: 600 28px"Open Sans";
    margin: 40px auto!important;
    width: 85%
}

.europe-hub .text18,.europe-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
}

.europe-hub p.__pfs,.europe-hub ul.__pfs li.__pfs,.usa-hub p.__pfs,.usa-hub ul.__pfs li.__pfs {
    font: 14px Open Sans
}

.europe-hub .push-left,.sun-hub .push-left {
    text-align: left;
    margin-bottom: 15px
}

.europe-hub .sun-promo-box {
    background: #fff;
    box-shadow: 0 0 7px -3px rgb(84 84 84/75%);
    padding: 15px 4em 0;
    text-align: left
}

.europe-hub .sun-promo-box .sections:nth-of-type(1) {
    border-bottom: 2px solid #e6e6e6
}

.europe-hub .sun-promo-box .sections:nth-of-type(1) p.__pfs:last-child {
    margin-bottom: 35px
}

.europe-hub .sun-promo-box .sections:nth-of-type(2) {
    display: flex
}

.europe-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs {
    flex: 1;
    padding: 20px
}

.europe-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
}

.europe-hub .sun-promo-box .sections:nth-of-type(1) p.__pfs,.europe-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs p.__pfs {
    font-size: 14px
}

.europe-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs:first-child {
    padding-left: 0
}

.europe-hub .sun-promo-box .ntp-tooltip button.block-align.copy-code.primary-btn {
    width: 100%;
    margin: 10px 0
}

.europe-hub .sun-promo-box .ntp-tooltip {
    padding: 0 0 0 48px!important
}

.europe-hub .sun-promo-box .ntp-tooltip .copy-icon,div.__pfs#companion .row.box.white-panel .ntp-tooltip button.block-align.copy-code .copy-icon,section#aeroplan-offer .ae-row {
    display: flex
}

.europe-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs:last-child {
    padding-right: 0
}

section#aeroplan-offer .ae-row .col-66 img.__pfs {
    height: 17px
}

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 form .form-control {
    border: 0;
    border-bottom: 1px solid #e6e6e6;
    box-shadow: none;
    border-radius: 0;
    padding: 10px
}

input#agreement {
    float: left
}

input#sign-up {
    float: none;
    margin: 20px auto;
    padding: 12px 45px
}

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)
}

.europe-hub .grey-bg .ae-content,.usa-hub .grey-bg .ae-content {
    display: flex;
    padding: 0 20px;
    margin: 40px auto
}

.europe-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
}

.europe-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.active {
    box-shadow: 5px 5px 5px 1px rgb(0 0 0/35%);
    z-index: 3;
    position: relative
}

.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
}

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
}

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 .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 .row.box.white-panel div.__pfs.col-33 {
    padding: 0;
    background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/Promotion.png)no-repeat center center;
    background-size: cover;
    display: block
}

div.__pfs#companion .row.box.white-panel div.__pfs.col-33 .red-pill {
    margin: 15px
}

div.__pfs#companion .row.box.white-panel .row.promotional-code {
    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#euro-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;
    box-shadow: 0 9px 12px -3px rgba(0,0,0,.12)
}

div.__pfs#euro-tabs .nav.nav-tabs li.__pfs.tab.active a.__pfs {
    font-weight: 600
}

div.__pfs#euro-tabs .nav.nav-tabs li.__pfs.tab:hover a.__pfs {
    background: #fff
}

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#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#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,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#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#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: 400px;
    margin: 0 20px;
    display: flex;
    flex-direction: column;
    box-shadow: 0 0 15px -3px rgb(0 0 0/20%)
}

div.__pfs#tour-packages .item-container .item div.__pfs {
    padding: 20px;
    height: 100%;
    display: flex;
    flex-direction: column
}

div.__pfs#flight-pass .item-container {
    display: flex;
    flex-direction: column;
    margin: 0 8em
}

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: 15px;
}

div.__pfs#flight-pass .item-container .item .fp-image {
    background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/hotels.jpg)no-repeat center center;
    background-size: cover;
    padding: 0;
    width: 100%;
    min-width: 275px
}

div.__pfs#flight-pass .item-container .item .fp-image.carRental {
    background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/carRental.jpg)no-repeat center center;
    background-size: cover;
    padding: 0;
    width: 100%;
    min-width: 275px
}

div.__pfs#flight-pass .item-container .item .fp-image.student {
    background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/fp-student.png)no-repeat center center;
    background-size: cover;
    padding: 0;
    width: 100%;
    min-width: 275px
}

div.__pfs#euro-tabs {
    margin: 25px 0 0;
    position: relative;
}

.cabin-container,div.__pfs#travel-perks .item-container {
    display: flex
}

div.__pfs#travel-perks .item-container .item {
    padding: 20px;
    flex: 1;
    display: flex;
    flex-direction: column;
    align-content: center;
    text-align: center
}

.cabin-container .item 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: 110px;
    height: 110px;
    margin: 0 auto
}

div.__pfs#travel-perks .ae-content {
    padding-top: 8em
}

div.__pfs#cabins {
    padding-top: 6em
}

.cabin-container .item {
    flex: 1;
    display: flex;
    flex-direction: column
}

.cabin-container .item:nth-of-type(2) {
    margin: 0 50px
}

.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
}

.destination-container .item {
    flex: 22.5%;
    text-align: center;
    margin: 15px;
    box-shadow: 0 0 15px -3px rgba(0,0,0,.2)
}

.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
}

.europe-hub div.__pfs.gradient-clouds-bg,.europe-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%
}

.europe-hub div.__pfs.gradient-clouds-bg+.ae-content,.europe-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
}

.europe-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;
}

.mobile-content,.InteractiveMap.init {
    display: none
}

.InteractiveMap.active {
    display: block!important;
    visibility: visible!important
}

div.__pfs#all-destinations .ae-content,div.__pfs#companion .ae-content,div.__pfs#earn-bonus-points .ae-content {
    padding-bottom: 0
}

.destination-container .item img.__pfs {
    object-fit: cover;
    height: 170px
}

.destination-container+.backToTop {
    margin-bottom: 3em
}

@media only screen and (min-width:1201px) {
    .europe-hub .ae-content,.usa-hub .ae-content {
        width: 1200px;
        margin: 0 auto
    }

    div.__pfs#euro-tabs .nav.nav-tabs {
        width: 1200px;
        max-width: calc(100% - 40px);
        margin: auto
    }

    .europe-hub .header-row .hero-image,.usa-hub .header-row .hero-image {
        width: 1200px!important;
        padding-left: 0!important;
        margin: 0 auto 10em
    }

    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 {
        margin: 0 auto;
        width: calc(1200px - 16em);
        max-width: 1200px
    }

    div.__pfs.tc-panel-container {
        margin-top: 4em!important
    }
}

@media only screen and (max-width:1201px) and (min-width:1025px) {
    /*.Campaign.lg\:max-w-6xl.self-center,.module-row.module-row--campaign_widget+.container {
        width: 100%;
        max-width: calc(100% - 100px)
    }*/

    .europe-hub .header-row,.usa-hub .header-row {
        justify-content: end
    }

    .europe-hub .header-row .hero-image,.usa-hub .header-row .hero-image {
        margin: 0 auto 10em
    }

    div.__pfs.tc-panel-container {
        margin-top: 4em!important
    }
}

@media only screen and (max-width:1200px) and (min-width:768px) {
    .europe-hub .sun-promo-box .sections:nth-of-type(2) {
        flex-wrap: wrap
    }

    .europe-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs:last-child {
        flex-basis: 100%;
        padding: 20px 0
    }

    .europe-hub .sun-promo-box .ntp-tooltip button.block-align.copy-code.primary-btn {
        width: fit-content;
        max-width: 255px
    }

    .europe-hub .nav.nav-tabs,.usa-hub .nav.nav-tabs {
        width: calc(100% - 60px);
        max-width: 100%;
        margin: 0 auto;
    }

    .europe-hub .nav.nav-tabs + .tab-content,
    .usa-hub .nav.nav-tabs + .tab-content {
        margin: 0 auto;
        width: 100%;
    }

    div.__pfs#advance-seat-selection .row,div.__pfs#earn-bonus-points .row {
        flex-direction: column
    }

    div.__pfs#advance-seat-selection .row .col-50,div.__pfs#earn-bonus-points div.__pfs.row .col-50,div.__pfs#earn-bonus-points div.__pfs.row .col-50.white-panel {
        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#tour-packages .item-container {
        margin: 0 30px;
        flex-direction: column
    }

    div.__pfs#tour-packages .item-container .item {
        max-width: 100%;
        margin: 20px 0
    }

    div.__pfs#flight-pass {
        margin-top: 0
    }

    div.__pfs#flight-pass .item-container {
        margin: 0 30px
    }

    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 {
        height: 140px
    }

    div.__pfs#flight-pass .item-container .item .fp-image {
        height: 350px;
        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%
    }
}

@media only screen and (min-width:1025px) {
    .europe-hub .header-row,.usa-hub .header-row {
        height: 500px
    }

    div.__pfs#euro-tabs {
        padding-top: 50px
    }

    :lang(fr) div.__pfs#euro-tabs {
        padding-top: 80px
    }

    .europe-hub .header-row .hero-image,.usa-hub .header-row .hero-image {
        padding-left: 2em;
        width: 100%;
        height: 350px
    }

    .europe-hub .ae-content.top,.usa-hub .ae-content.top {
        margin-top: -200px
    }

    .europe-hub .ae-content.top .module-row.module-row--price_widget .container,.europe-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
    }

    .europe-hub .nav.nav-tabs,.usa-hub .nav.nav-tabs {
        display: flex
    }

    .europe-hub .nav.nav-tabs li.__pfs,.usa-hub .nav.nav-tabs li.__pfs {
        flex: 25%
    }
}

@media only screen and (max-width:1024px) and (min-width:768px) {
    .europe-hub .ae-content#top,.usa-hub .ae-content#top {
        margin-bottom: -80px
    }

    .europe-hub .header-row .hero-image,.usa-hub .header-row .hero-image {
        padding-left: 2em;
        width: 100%;
        height: 350px
    }

    .europe-hub .header-row {
        height: 350px;
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/hero-euroHub-tablet.jpg)no-repeat center center
    }

    .europe-hub.may .header-row {
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/euro-hub-may.jpg)no-repeat center center;
        background-size: cover
    }

    .europe-hub.august .header-row {
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/hero-europe-sale-tablet.png)no-repeat center center;
        background-size: cover
    }

    .europe-hub.april .header-row {
        height: 350px;
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/hero-euroHub-tablet-april.jpg)no-repeat center center
    }

    .europe-hub.seatSale .header-row {
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/hero-euroHub-tablet-seatSale.jpg)no-repeat center center
    }

    .europe-hub.seatSale.v2 .header-row {
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/hero-euroHub-tablet-seatSale-april.jpg)no-repeat center center
    }

    div.__pfs#euro-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 .ae-content {
        padding: 4em 15px
    }

    div.__pfs#earn-bonus-points p.__pfs.grey-bg {
        margin-left: 20%
    }

    .destination-container {
        display: flex!important;
        flex-wrap: wrap!important;
        background: #fff
    }

    div.__pfs#earn-bonus-points div.__pfs.row .col-50 .item {
        width: 80%;
        padding-left: 20%
    }

    div.__pfs#join-aeroplan form .form-control {
        background: #fff
    }

    .europe-hub .grey-bg .ae-content p.__pfs:first-child,.usa-hub .grey-bg .ae-content p.__pfs:first-child {
        border-left: none
    }

    .europe-hub .grey-bg .ae-content p.__pfs:last-child,.usa-hub .grey-bg .ae-content p.__pfs:last-child {
        border-right: none
    }

    .europe-hub .grey-bg .ae-content,.usa-hub .grey-bg .ae-content {
        padding: 0
    }

    .blue-bg .ae-content {
        padding: 0;
        width: 100%
    }

    .europe-hub .nav.nav-tabs,.usa-hub .nav.nav-tabs {
        display: flex
    }

    .europe-hub .nav.nav-tabs li.__pfs,.usa-hub .nav.nav-tabs li.__pfs {
        flex: 25%
    }

    .europe-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
    }

    /*.Campaign.lg\:max-w-6xl.self-center,.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#companion .row.box.white-panel .ntp-tooltip {
        width: 70%
    }

    div.__pfs#companion .row.box.white-panel .ntp-tooltip button.block-align.copy-code {
        flex-direction: column
    }
}

@media only screen and (max-width:767px) {
    div.__pfs#euro-tabs {
        margin: 20%0 0
    }

    .europe-hub h1.__pfs,.usa-hub h1.__pfs {
        font-size: 32px;
        line-height: 1.12;
        margin-bottom: 10px
    }

    .europe-hub h2.__pfs,.usa-hub h2.__pfs {
        font-size: 24px;
        line-height: 1.12;
        margin-bottom: 12px;
        width: 95%;
        padding: 20px 0 0
    }

    .europe-hub .h2.__pfs-like,.usa-hub .h2.__pfs-like {
        font-size: 24px;
        margin: 25px auto;
        width: 95%
    }

    .europe-hub h3.__pfs,.usa-hub h3.__pfs {
        font-size: 16px;
        font-weight: 700
    }

    .europe-hub p.__pfs,.europe-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
    }

    .europe-hub .sun-promo-box .sections:nth-of-type(2) {
        flex-direction: column
    }

    .europe-hub .sun-promo-box .sections:nth-of-type(2) div.__pfs {
        padding: 10px 0
    }

    .europe-hub .sun-promo-box {
        padding: 20px 20px 0
    }

    .europe-hub .ae-content,.usa-hub .ae-content {
        padding: 2em 0
    }

    .europe-hub .ae-content.top,.usa-hub .ae-content.top {
        margin-top: -8em;
        padding: 20px 0
    }

    .europe-hub .header-row .hero-image {
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/hero-euroHub-mobile.jpg)no-repeat center center;
        background-size: cover;
        margin: 0
    }

    .europe-hub.may .header-row .hero-image {
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/euro-hub-may-mobile.jpg)no-repeat center center;
        background-size: cover;
        margin: 0
    }

    .europe-hub.august .header-row .hero-image {
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/hero-europe-sale-mobile.png)no-repeat center center;
        background-size: cover;
        margin: 0;
        display: none;
    }

    .europe-hub.april .header-row .hero-image {
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/hero-euroHub-mobile-april.jpg)no-repeat center center;
        background-size: cover;
        margin: 0
    }

    .europe-hub.seatSale .header-row .hero-image {
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/hero-euroHub-mobile-seatSale.jpg)no-repeat center center;
        background-size: cover
    }

    .europe-hub.seatSale.v2 .header-row .hero-image {
        background: url(https://www.aircanada.com/content/dam/aircanada/airtrfx/images/campaigns/europe-hub/hero-europe-v2.jpg)no-repeat center center;
        background-size: cover
    }

    .europe-hub .ae-content#top,.usa-hub .ae-content#top {
        margin-bottom: 0;
        margin-top: 200px;
        padding: 0 15px
    }

    .europe-hub .ae-content#top h1.__pfs {
        font-size: 28px
    }

    div.__pfs#travel-perks .ae-content {
        padding: 0
    }

    .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
    }

    div.__pfs#top-offers .gradient-clouds-bg+.ae-content {
        margin-top: -12em
    }

    .destination-container .item img.__pfs {
        height: auto
    }

    .europe-hub div.__pfs.gradient-clouds-bg+.ae-content,.europe-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
    }

    .cabin-container,div.__pfs#earn-bonus-points .row,div.__pfs#earn-bonus-points div.__pfs.row .col-50 .item,div.__pfs#top-offers .item-container,div.__pfs#travel-perks .item-container {
        flex-direction: column
    }

    .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
    }

    .europe-hub button.slick-next,.europe-hub button.slick-next:hover,.europe-hub button.slick-prev,.europe-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%
    }

    .europe-hub button.slick-next,.europe-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
    }

    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-container,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
    }

    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
    }

    .europe-hub .grey-bg .ae-content p.__pfs:first-child,.usa-hub .grey-bg .ae-content p.__pfs:first-child {
        border-left: none
    }

    .europe-hub .grey-bg .ae-content p.__pfs:last-child,.usa-hub .grey-bg .ae-content p.__pfs:last-child {
        border-right: none
    }

    .europe-hub .grey-bg .ae-content,.usa-hub .grey-bg .ae-content {
        padding: 0
    }

    .europe-hub .nav.nav-tabs li.__pfs.active a.__pfs:after,.europe-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 {
        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
    }

    .europe-hub .nav.nav-tabs,.usa-hub .nav.nav-tabs {
        display: flex;
        flex-wrap: wrap
    }

    .europe-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
    }

    /*.Campaign.lg\:max-w-6xl.self-center,.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
    }

    .europe-hub .nav.nav-tabs li.__pfs img.__pfs,.usa-hub .nav.nav-tabs li.__pfs img.__pfs {
        max-width: 100%
    }

    .europe-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#euro-tabs .nav.nav-tabs.is-open li.__pfs.active,div.__pfs#euro-tabs .nav.nav-tabs.is-open li.__pfs:hover,div.__pfs#euro-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#euro-tabs .nav.nav-tabs,div.__pfs#euro-tabs .nav.nav-tabs.is-open li.__pfs.active a.__pfs:after {
        display: none
    }

    div.__pfs#euro-tabs .nav.nav-tabs.is-open {
        display: block;
        flex-direction: column;
        width: 100%;
        margin: 0 auto;
        position: absolute;
        z-index: 10;
        background: #fff
    }

    div.__pfs#euro-tabs .nav.nav-tabs.is-open li.__pfs {
        display: flex;
        font-size: 16px;
        width: 100%
    }

    div.__pfs#euro-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#euro-tabs .nav.nav-tabs.is-open li.__pfs a.__pfs img.__pfs {
        margin: 0 10px 0 0;
        width: 17px
    }

    div.__pfs#earn-bonus-points p.__pfs.grey-bg {
        margin-bottom: 40px
    }

    div.__pfs#companion .row.box.white-panel div.__pfs.col-33 {
        height: 300px
    }

    div.__pfs#companion .row.box.white-panel div.__pfs.col-33 .red-pill {
        margin: 5px
    }

    .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: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
    }
}

@media only screen and (max-width:767px) and (min-width:415px) {
    .europe-hub .header-row .hero-image,.usa-hub .header-row .hero-image {
        height: 350px
    }
}

@media only screen and (max-width:414px) {
    .europe-hub .header-row .hero-image,.usa-hub .header-row .hero-image {
        height: 250px
    }
}

.europe-hub,.usa-hub {
    width: 100%;
    max-width: 100%;
    overflow: hidden
}