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

.Campaign .hub-template.japan-spring23 div.tab-pane .py-2:not(.w-full) [data-em-cmp="price_widget"] {
    max-width: 71rem;
}

.Campaign ul.nav.nav-tabs.__pfs {width: 100%; margin-bottom: 0; border-bottom: 0;}
.Campaign div.tab-content {width: 100%; margin: 0 auto; }
.Campaign .px-3, .Campaign .py-4 {
    padding: 0 !important
}
div#redirect-container{
    width: 100%;
    max-width: 1200px;
    /* margin: -20px 0px 40px 0px; */
    border: 1px solid #C1C5C8;
    background-color: #F5F5F5;
    margin: 0 auto;
    margin-top: 20px;
}
div#redirect-container p i.icon-info{
    margin-right: 5px;
    color: #005078;
}
.notif-copy{
    display: flex;
    align-items: center;
    margin: 0;
    padding: 20px;
    font-size: 14px;
    line-height: 20px;
}
button.slick-next, button.slick-next{
    transform: rotate(0deg)!important;
}
button.slick-next, button.slick-next:hover{
    transform: rotate(0deg)!important;
}

/* Footnote disclaimer below all grids */
p.vg-f.tracking-normal.vg-e.vg-F.vg-g.vg-H.vg-I.vg-AA.vg-AB {
    font-size: 12px;
}
p[data-test='disclaimer'] a {
    font-weight: 700;
    text-decoration: none;
}

/* Points carousel on flights to usa */
.max-w-full.pb-1.break-words span {
    display: inline;
}

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

.hub-template h1.__pfs.__bss+img {
    width: 180px;
    margin: 10px auto
}

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

.hub-template h1,.hub-template h1.__pfs.__bss {
    font: 300 36px Open Sans;
    margin: 30px auto;
    text-align: center;
    font-weight: 700
}

.hub-template.usa div.tc-panel-container {
    width: calc(100% - 60px);
    padding: 0
}

.hub-template.japan-spring23 div.tc-panel-container {
    max-width: 71rem;
    margin-bottom: 0;
}

.hub-template.japan-spring23 .tc-panel-content {
    max-width: 71rem;
}

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

.hub-template h2.__pfs.__bss:not(.h2-like):after,.hub-template h2:not(.h2-like):after {
    content: "";
    display: block;
    background-color: #bba88d;
    width: 20px;
    height: 2px;
    margin: 20px auto
}

.hub-template h2.__pfs.__bss+p:not(.booking-mask-popup) {
    font-size: 15px;
    width: 80%;
    margin: 0 auto 30px;
    text-align: center
}

.hub-template.japan-spring23 h2.__pfs.__bss+p:not(.booking-mask-popup) {
    font-size: 18px;
    width: 81%;
    margin: 0 auto 30px;
    text-align: center
}

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

.hub-template p.__pfs.__bss {
    font: 14px Open Sans
}

.hub-template .sun-promo-box .sections:nth-of-type(2) p:first-child span {
    width: 40px;
    height: 40px;
    background: #d8292f;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-right: 8px
}

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

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

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

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

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

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

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

label#rules-check a,label#rules-check a.__pfs.__bss {
    font-weight: 600!important
}

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

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

.hub-template .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
}

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

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

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

.blue-bg .ae-content nav .nav-tabs li 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.active a.__pfs.__bss {
    border-top: solid 3px #005078
}

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

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

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

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

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

#flight-pass .ae-content .white-panel h3.__pfs.__bss:before,#flight-pass .ae-content .white-panel h3: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%)
}

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

.hub-template .nav.nav-tabs li.tab a.__pfs.__bss {
    display: flex;
    flex-direction: column;
    font-weight: 400;
    align-items: center;
    padding: 20px 0px;
    height: 100%;
    box-shadow: 0 9px 12px -3px rgb(0 0 0 / 12%);
    justify-content: center;
    font-size: 18px;
    color: #000!important;
    max-width: 100%;
    width: 500px;
}

.hub-template .nav.nav-tabs li.tab.active a,.hub-template .nav.nav-tabs li.tab.active a.__pfs.__bss {
    font-weight: 700;
    color: #000
}

.bottom .nav.nav-tabs li.tab.active a,.bottom .nav.nav-tabs li.tab.active a.__pfs.__bss {
    border-top: solid 3px #005078;
    border-bottom: none
}

.bottom li.active a.__pfs.__bss {
    border-bottom: none!important
}

.bottom a.__pfs.__bss,.bottom li.tab a.__pfs.__bss {
    padding: 0!important
}

.hub-template .nav.nav-tabs li.active a img,.hub-template .nav.nav-tabs li.active a.__pfs.__bss img {
    top: 0
}

.hub-template .nav.nav-tabs li.tab:hover a,.hub-template .nav.nav-tabs li.tab:hover a.__pfs.__bss {
    background: #fff
}

.copy a.__pfs.__bss {
    align-items: flex-end;
    width: 100%;
    margin-top: auto
}

#top-offers .item-container .item h3.__pfs.__bss {
    font-weight: 700
}

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

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

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

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

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

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

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

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

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

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

#tour-packages .item-container .item h3.__pfs.__bss,.hub-template.usa #explore #themes .row.white-panel div.col-50 p.__pfs.__bss {
    text-align: left
}

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

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

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

#flight-pass .ae-content .white-panel a:last-child,#travel-perks .item-container .item p.__pfs.__bss:last-child,.cabin-container .item p.__pfs.__bss:last-child {
    margin-top: auto
}

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

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

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

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

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

.destination-container .item p.__pfs.__bss+p,.hub-template .row.box .bottom.row .promotional-code p.__pfs.__bss .promo strong {
    font-size: 14px
}

.hub-template h2.__pfs.__bss.gradient-clouds-bg {
    padding: 50px 21em 50px 23em;
    font-size: 16px;
    font-weight: 400;
    line-height: 24px;
    width: 100vw;
    position: relative;
    left: calc(-50vw + 50%);
    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;
    margin-top: 55px
}

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

.nav-tabs-explore li.active {
    box-shadow: 0 9px 12px -3px rgb(0 0 0/12%)
}

.nav-tabs-explore li.active a.__pfs.__bss {
    background: #fff;
    padding: 20px 0;
    border-bottom: solid 3px #005078
}

.hub-template .row.box h2.__pfs.__bss:after {
    display: none
}

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

    .hub-template .ae-header .hero-image {
        padding-left: 0!important;
        margin: 0 auto 10em
    }

    .tc-panel-container {
        margin-top: 0!important
    }

    .hub-template.usa .boats-bg {
        margin-bottom: 6em
    }
}

@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)
    }

    .hub-template .header-row {
        justify-content: end
    }

    .hub-template .ae-header .hero-image {
        margin: 0 auto 10em
    }

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

@media only screen and (max-width:1200px) and (min-width:768px) {
    #explore .gradient-clouds-bg {
        padding: 50px 6px 50px 20px
    }

    .top .col-50 {
        margin: 30px 14px 30px 16px
    }

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

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

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

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

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

    #advance-seat-selection .row .col-50,#earn-bonus-points .row .col-50,#earn-bonus-points .row .col-50.white-panel {
        width: 100%
    }

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

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

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

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

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

    #flight-pass {
        margin-top: 0
    }

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

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

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

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

    .destination-container .item img {
        height: 140px
    }

    #flight-pass .item-container .item .fp-image {
        height: 350px;
        width: 300%
    }

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

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

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

    .hub-template:not(.seat-sale) {
        padding-top: 50px
    }

    .hub-template.usa {
        padding-top: 0
    }

    :lang(fr) .hub-template:not(.usa) {
        padding-top: 80px
    }

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

    .hub-template .ae-content.top {
        margin-top: -200px
    }

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

    .InteractiveMap {
        margin: 0-30px
    }

    .hub-template .nav.nav-tabs {
        display: flex;
        justify-content: center;
        width: 100%;
        margin-bottom: 0;
    }
    div#hub-tabContent {
        margin: 0 auto;
        width: 100%;
    }

    .hub-template .nav.nav-tabs li {
        flex: 0 1 25%
    }
}

@media only screen and (max-width:1024px) and (min-width:768px) {
    .hub-template .ae-header .hero-image {
        padding-left: 2em;
        width: 100%;
        height: 350px
    }

    .hub-template .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
    }

    .hub-template.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
    }

    .hub-template.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
    }

    .hub-template.usa .ae-header .hero-image {
        background: url(/content/dam/aircanada/airtrfx/images/campaigns/usa/hero-thailand-tablet.png)no-repeat right center;
        background-size: cover;
        height: 512px
    }

    .hub-template.usa.japan .ae-header .hero-image {
        background: url(/content/dam/aircanada/airtrfx/images/campaigns/japan/11801546_AC-Japan-Destination_Carousel_772x460.jpg)no-repeat right center;
        background-size: cover;
        height: 512px
    }

    .hub-template.usa .boats-bg {
        background: url(/content/dam/aircanada/airtrfx/images/campaigns/usa/boats-bg-tablet.png)no-repeat center center;
        background-size: cover;
        height: 370px
    }

    div#themes .ae-content {
        padding: 0 40px
    }

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

    .hub-template:not(.seat-sale) {
        margin-top: 6.5em!important
    }

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

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

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

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

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

    #earn-bonus-points .row .col-50 .item {
        width: 80%;
        padding-left: 20%
    }

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

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

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

    .hub-template .grey-bg .ae-content {
        padding: 0
    }

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

    .hub-template .nav.nav-tabs {
        display: none;
        align-items: baseline
    }

    .nav.bottom {
        display: flex!important;
        width: auto!important;
        position: relative!important;
        margin: auto!important;
        flex-direction: row!important
    }

    .hub-template .nav.nav-tabs li {
        flex: 25%
    }

    .bottom.nav.nav-tabs li {
        padding: 2em 0 0
    }

    .hub-template .nav.nav-tabs li.tab a.__pfs.__bss {
        justify-content: flex-end
    }

    .hub-template .nav.nav-tabs li img {
        max-width: 100%
    }

    .bottom .nav.nav-tabs li:nth-child(1) img,.bottom .nav.nav-tabs li:nth-child(5) {
        position: relative
    }

    .bottom .nav.nav-tabs li:nth-child(1) a,.bottom .nav.nav-tabs li:nth-child(5) a.__pfs.__bss {
        top: 24px
    }

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

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

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

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

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

    .mobile-content {
        display: flex!important;
        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
    }

    .mobile-content span.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
    }

    .hub-template .nav.nav-tabs.is-open {
        display: block;
        flex-direction: column;
        width: 100%;
        margin: 0 auto;
        top: 55px;
        padding: 0;
        border: 1px solid #e6e6e6;
        position: absolute;
        z-index: 10;
        background: #fff
    }

    .hub-template .nav.nav-tabs.is-open li {
        display: flex;
        font-size: 16px;
        width: 100%
    }

    .bottom.nav.nav-tabs.is-open li a.__pfs.__bss,.hub-template .nav.nav-tabs.is-open li 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
    }

    .bottom.nav.nav-tabs.is-open li a.__pfs.__bss span,.hub-template .nav.nav-tabs.is-open li a.__pfs.__bss span {
        font-size: 16px;
    }

    .bottom.nav.nav-tabs.is-open li a.__pfs.__bss {
        flex-direction: column!important;
        align-items: flex-start;
        justify-content: flex-end
    }

    .bottom span {
        width: 100%;
        padding: 1em;
        height: 100px!important;
        text-align: center;
        font-size: 16px;
        font-weight: 700
    }

    .hub-template .nav.nav-tabs.is-open li a.__pfs.__bss img {
        margin: 0 10px 0 0;
        width: 17px;
        height: 17px;
    }

    ul li span {
        display: block;
        overflow-y: hidden
    }

    .bottom.nav.nav-tabs.is-open li a.__pfs.__bss img,.hub-template .text18,.hub-template h2.__pfs.__bss,.hub-template h2.__pfs.__bss+p {
        width: 100%
    }
}

@media only screen and (max-width:767px) {
    #comfort .gradient-clouds-bg {
        margin-top: 1px
    }

    .top .col-50 {
        margin: 33px
    }

    .desktop-content,.hub-template .nav.nav-tabs li.active a:after,.hub-template .nav.nav-tabs li.active:after {
        display: none
    }

    .mobile-content {
        display: flex!important
    }

    #explore .carousel {
        display: block;
        background-color: transparent
    }

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

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

    .hub-template .h2-like {
        font-size: 24px;
        margin: 25px auto;
        width: 95%
    }

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

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

    a.backTop {
        margin-top: 4em
    }

    .hub-template .sun-promo-box .sections:nth-of-type(2) {
        flex-direction: column;
        padding: 10px 0
    }

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

    .hub-template .ae-content {
        padding: 1em 20px;
    }

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

    .hub-template .header-row {
        background: 0 0;
        height: auto
    }

    .highlight svg {
        width: 24px
    }

    .hub-template .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
    }

    .hub-template.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
    }

    .hub-template.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
    }

    .hub-template.usa .ae-header .hero-image {
        background: url(/content/dam/aircanada/airtrfx/images/campaigns/usa/hero-thailand-mobile.png)no-repeat right center;
        background-size: cover;
        height: 280px;
        width: 100%
    }

    .hub-template.usa .boats-bg {
        background: url(/content/dam/aircanada/airtrfx/images/campaigns/usa/boats-bg-mobile.png)no-repeat center center;
        background-size: cover;
        height: 370px
    }

    div#tab-container {
        margin: 0
    }

    .hub-template .ae-content#top {
        margin: -60px auto 0;
        width: calc(100% - 40px);
        padding: 0 20px
    }

    .hub-template .ae-content#top .h2-like,.hub-template .ae-content#top h2.__pfs.__bss+p:not(.booking-mask-popup) {
        width: 100%
    }

    /*.hub-template #featured-fares {
        height: 500px
    }*/

    .module-row.module-row--em-cmp-lib-airmodules__fare-carousel-with-filters--ac {
        margin-top: -31em
    }

    #travel-perks .ae-content {
        padding: 0
    }

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

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

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

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

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

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

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

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

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

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

    #mll {
        margin: 0 20px
    }

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

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

    .hub-template button.slick-next,.hub-template button.slick-next:hover {
        transform: rotate(180deg)!important;
    }

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

    #earn-bonus-points .row .col-50 .item {
        margin: 12.5px auto
    }

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

    #tc-panel-container-seat,.tc-panel-container,.tc-panel-content {
        width: calc(100% - 60px);
        margin: auto;
        display: block;
        padding-top: 10px
    }

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

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

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

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

    #flight-pass {
        margin-top: 0
    }

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

    #flight-pass .ae-content .description,#flight-pass .item-container .item,section#aeroplan-offer .ae-row {
        flex-direction: column
    }

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

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

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

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

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

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

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

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

    .hub-template .grey-bg .ae-content {
        padding: 0
    }

    .blue-bg .ae-content nav .nav-tabs li a.__pfs.__bss,.bouns p.__pfs.__bss {
        text-align: center
    }

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

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

    .hub-template .nav.nav-tabs {
        display: flex;
        flex-wrap: wrap
    }

    .hub-template .nav.nav-tabs li {
        flex: 50%
    }

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

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

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

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

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

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

    #tour-packages .tile {
        flex-direction: column
    }

    .hub-template .nav.nav-tabs li img {
        max-width: 100%
    }

    .hub-template 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
    }

    .hub-template .nav.nav-tabs.is-open li.active,.hub-template .nav.nav-tabs.is-open li:hover,.hub-template .nav.nav-tabs.is-open ul li:active,p.mobile-content:hover {
        cursor: pointer
    }

    p.mobile-content span.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.dropdown {
        transform: rotateZ(180deg)
    }

    .hub-template .nav.nav-tabs,.hub-template .nav.nav-tabs.is-open li.active a:after {
        display: none
    }

    .hub-template .nav.nav-tabs.is-open {
        display: block;
        flex-direction: column;
        width: 100%;
        margin: 0 auto;
        position: absolute;
        padding: 0;
        border: 1px solid #e6e6e6;
        top: 55px;
        z-index: 10;
        background: #fff
    }

    .hub-template .nav.nav-tabs.is-open li {
        display: flex;
        font-size: 16px;
        width: 100%
    }

    .hub-template .nav.nav-tabs.is-open li 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
    }
    .hub-template .nav.nav-tabs.is-open li a.__pfs.__bss span {font-size: 16px;}

    .hub-template .nav.nav-tabs.is-open li a.__pfs.__bss img {
        margin: 0 10px 0 0;
        width: 17px;
        height: 17px;
    }

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

    #offers .bouns p.__pfs.__bss {
        text-align: center!important
    }

    #offers p.__pfs.__bss:nth-child(1),#offers p.__pfs.__bss:nth-child(2) {
        padding: 10px!important
    }

    .hub-template .gradient-clouds-bg,.hub-template h2.__pfs.__bss.gradient-clouds-bg {
        padding: 50px 10px
    }

    .bouns {
        flex-direction: column!important;
        align-items: center
    }

    .bouns span {
        display: block
    }

    .gradient-clouds-bg .col-50:nth-child(3) {
        left: 0
    }

    #explore.slick-initialized .slick-slide {
        text-align: center
    }

    #explore .slick-slide article .col-xs-12:nth-child(2) {
        text-align: left;
        margin-top: 50px
    }

    #explore ul.slick-dots {
        position: relative;
        top: 10px;
        margin-bottom: 10px
    }

    #explore .slick-slide article .col-xs-12:nth-child(1) {
        background: #fff;
        -webkit-box-shadow: 0 6px 32px -19px rgb(0 0 0/30%),0 7px 16px -8px rgb(0 0 0/10%);
        box-shadow: 1px 1px 6px 0 rgb(0 0 0/30%),0 7px 16px -8px rgb(0 0 0/10%);
        padding: 0
    }

    #explore .slick-slide article .col-xs-12:nth-child(1) p {
        padding: 48px 20px;
        font-size: 16px!important;
        font-weight: 600;
        line-height: 24px;
        text-align: center
    }

    #explore .slick-slide article {
        margin: 0
    }

    #explore .slick-initialized .slick-slide {
        display: block;
        margin: 0 2em
    }

    .hub-template .row.box #offset-ht p.__pfs.__bss.block-align {
        margin-left: 0;
        padding-left: 0!important
    }

    #offers&gt;div.row.box&gt;div.bottom.row&gt;div.col-lg-8.col-md-8.col-sm-8.col-xs-12 {
        height: 0
    }
}

@media only screen and (max-width:767px) and (min-width:415px) {
    .hub-template .ae-header .hero-image {
        height: 350px
    }
}

@media only screen and (max-width:414px) {
    .hub-template .ae-header .hero-image {
        height: 250px
    }

    .hub-template .row.box #offset-ht p.__pfs.__bss.block-align {
        margin-left: 0;
        padding-left: 0!important
    }

    #offers&gt;div.row.box&gt;div.bottom.row&gt;div.col-lg-8.col-md-8.col-sm-8.col-xs-12 {
        height: 0
    }
}

@media only screen and (max-width:1400px) and (min-width:1205px) {
    #explore .gradient-clouds-bg {
        padding: 50px 0
    }

    #comfort .gradient-clouds-bg {
        padding: 50px 97px 50px 133px
    }
}

@media only screen and (min-width:767px) and (max-width:1204px) {
    #explore .gradient-blue-bg,.hub-template .gradient-clouds-bg {
        padding: 50px 0;
        left: 0;
        text-align: center
    }

    #comfort .gradient-blue-bg {
        padding: 50px 20px
    }

    .gradient-blue-bg .col-50:nth-child(3) {
        left: 0
    }

    .cabin-container {
        flex-direction: row;
        text-align: left;
        flex-wrap: wrap
    }

    .cabin-container .item {
        padding: 5px 10px
    }

    .cabin-container img {
        width: 100%;
        max-width: 100%;
        margin: 20px auto
    }

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

    div#comfort .ae-content .h2-like {
        margin: 0 auto 30px!important
    }
}

#offers p.__pfs.__bss {
    text-align: center;
    font-size: 15px;
    font-weight: 400;
    padding: 0px 120px;
}

#offers .bouns p.__pfs.__bss {
    text-align: left;
    font-size: 14px!important;
    padding: 0!important
}

.bouns p.__pfs.__bss:nth-child(1) {
    font-size: 20px!important;
    font-weight: 700!important
}

.form-wrapper input[type=checkbox] {
    margin: 0 10px 0 0
}

.form-wrapper label {
    font-weight: 400;
    font-size: 14px
}

.form-wrapper label a,.form-wrapper label a.__pfs.__bss {
    font-size: 14px;
    font-weight: 600
}

.highlight p.__pfs.__bss {
    text-align: left!important;
    font-size: 14px!important;
    padding: 0!important
}

.hub-template.usa #explore #themes .row.white-panel div.col-50 {
    padding: 30px;
    margin-right: auto
}

.tc-panel-content ul li a,.tc-panel-content ul li a.__pfs.__bss {
    line-break: anywhere
}

@media only screen and (min-width:768px) and (max-width:1024px) {
    .hub-template.usa #explore #themes .row.white-panel img.col-50 {
        max-height: none;
        min-height: 200px;
        width: auto;
        max-width: 50%;
        object-fit: cover
    }

    .cabin-container .item,.cabin-container .item:nth-of-type(2) {
        max-width: 700px;
        margin: 10px auto
    }

    /*.hub-template #featured-fares {
        height: 500px
    }*/

    .module-row.module-row--em-cmp-lib-airmodules__fare-carousel-with-filters--ac {
        margin-top: -30em
    }

    .hub-template .ae-content#top {
        margin: -80px auto 0;
        width: calc(100% - 40px)
    }
}

@media only screen and (max-width:767px) {
    .hub-template.usa #explore #themes .row.white-panel {
        flex-direction: column
    }

    .hub-template.usa #explore #themes .row.white-panel:nth-of-type(even) {
        flex-direction: column-reverse
    }

    .hub-template.usa #explore #themes .row.white-panel img.col-50 {
        max-height: 260px;
        min-height: 100px;
        width: auto;
        max-width: 100%;
        object-fit: cover;
        object-position: top;
        flex: none
    }

    .hub-template .text18,.hub-template h2.__pfs.__bss+p:not(.booking-mask-popup) {
        width: 90%
    }
    #offers p.__pfs.__bss {
        text-align: center;
        font-size: 15px;
        font-weight: 400;
        padding: 0px 20px;
    }
    .mon-m{
        flex-direction: column-reverse!important;
        display: flex!important;
    }
}

#offers p.__pfs.__bss:nth-child(1),#offers p.__pfs.__bss:nth-child(2) {
    padding: 0 9em
}

.usa #offers p.__pfs.__bss:nth-child(1),.usa #offers p.__pfs.__bss:nth-child(2),.gradient-cloud-bg p.__pfs.__bss:nth-child(1),.gradient-cloud-bg p.__pfs.__bss:nth-child(2) {
    padding: 0
}

.gradient-clouds-bg p.__pfs.__bss:nth-child(1) {
    padding: 0!important
}

.covid-box p.__pfs.__bss {
    padding: 0!important;
    font-size: 16px!important;
    text-align: left!important;
    font-weight: 400
}

@media only screen and (min-width:2500px) {
    .hub-template .gradient-clouds-bg,.hub-template h2.__pfs.__bss.gradient-clouds-bg {
        padding: 50px 35em 50px 42em
    }

    .bottom {
        margin: 80px 7em 80px 1em
    }

    .top .col-50 {
        margin: 30px 111px 30px 16px
    }

    .map img {
        margin: 0 1em
    }

    #comfort .gradient-clouds-bg {
        padding: 50px 40em 50px 43em
    }
}

.hub-template .row.box h2,.hub-template .row.box h2.__pfs.__bss {
    text-align: left;
    font: 600 24px"Open Sans";
    margin: 0 auto 23px!important;
    padding: 20px 0 0;
    width: 100%
}

.hub-template .row.box #offset-ht p.__pfs.__bss {
    padding: 0;
    font-size: 14px;
    text-align: left!important;
    width: 100%;
    margin-bottom: 15px
}

.hub-template .row.box .bottom.row .promotional-code p,.hub-template .row.box .bottom.row .promotional-code p.__pfs.__bss,.hub-template .tc-panel-content p.__pfs.__bss {
    width: 100%;
    padding: 0!important;
    text-align: left!important
}

.hub-template .row.box .bottom.row .ntp-container .countdown .sale p.__pfs.__bss.countDownHeader,.hub-template .row.box .bottom.row .ntp-container .countdown .sale p.countDownHeader {
    width: 100%;
    padding: 5px!important
}

.hub-template .row.box #offset-ht p.__pfs.__bss.block-align {
    padding-right: 20px
}

.hub-template .tc-panel-content p.__pfs.__bss {
    font-size: 14px!important
}

.tab-pane {
    padding: 50px 0
}

div#tab-container {
    margin: 0!important;
    position: relative;
}

#hub-tabContent .tab-pane {
    padding: 0
}

.hub-template h1+img {
    width: 180px;
    margin: 10px auto
}

.hub-template .ae-header {
    width: 100%;
    max-width: 100%;
    display: flex;
    justify-content: end;
    flex-direction: column
}

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

.top .col-50 a:after {
    content: "&gt;";
    margin: auto 2px
}

:lang(fr) .hub-template:not(.usa) .header-row .ae-content {
    margin-bottom: -100px
}

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

.hub-template .ae-content a:hover:not(.primary-btn) {
    text-decoration: underline!important
}

.hub-template .primary-btn {
    width: 200px;
    margin: 10px auto
}

.hub-template .ae-header .hero-image {
    max-width: 100%;
    margin: 0 0 10em
}

.hub-template.usa .ae-header .hero-image {
    background: url(/content/dam/aircanada/airtrfx/images/ny-apac-6f-airtrfx.jpg)no-repeat right top;
    background-size: cover;
    height: 480px;
    margin: 0 auto
}

.hub-template.usa.japan .ae-header .hero-image {
    background: url(/content/dam/aircanada/airtrfx/images/campaigns/japan/11801546_AC-Japan-Destination_airtrfxLandingPage_1440x480.jpg)no-repeat right top;
    background-size: cover;
    height: 480px;
    margin: 0 auto
}

.hub-template.usa .boats-bg {
    background: url(/content/dam/aircanada/airtrfx/images/campaigns/usa/boats-bg.png)no-repeat center center;
    background-size: cover;
    height: 345px;
    text-align: center
}

.hub-template.usa.afterGrid {
    text-align: center
}

.module-row.module-row--em-cmp-lib-airmodules__fare-carousel-with-filters--ac {
    margin-top: -23em
}

img.logo-acv-carousel {
    margin: 30px auto!important;
    max-width: 216px!important;
    height: 42px!important
}

p.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,span.red {
    color: #d8292f
}

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

.blue-text {
    color: #005078
}

.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
}

div#themes {
    margin: 0;
    padding: 0px!important;
}

p#acDbaasAeroplanNumberError,p#acDbaasRulesCheckError {
    color: red
}

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

.hub-template #comfort .h2-like {
    margin: 0 auto 30px!important
}

.hub-template .text18,.hub-template h2+p:not(.booking-mask-popup) {
    font-size: 18px;
    width: 70%;
    margin: 0 auto 30px;
    text-align: center
}

.hub-template p,.hub-template ul li {
    font: 14px Open Sans
}

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

/*.hub-template #featured-fares {
    height: 400px
}*/

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

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

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

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

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

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

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

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

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

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

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

.hub-template .sun-promo-box .ntp-tooltip .copy-icon,section#aeroplan-offer .ae-row {
    display: flex
}

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

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

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

#join-aeroplan {
    margin: 0 0 30px 3em
}

#join-aeroplan,#join-aeroplan h3,#join-aeroplan p {
    text-align: left
}

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

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

#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.backToTop {
    text-decoration: none;
    margin: 3em auto 0;
    text-align: center;
    display: flex;
    justify-content: center
}

.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)
}

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

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

.hub-template .grey-bg .ae-content p a {
    padding: 0 20px;
    text-align: CENTER
}

.hub-template .grey-bg .ae-content p: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 a {
    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.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.active a {
    border-top: solid 3px #005078
}

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

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

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

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

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

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

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

#flight-pass {
    background-size: cover
}

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

#flight-pass .ae-content .description {
    display: flex;
    margin: 3em 0 20px;
    flex: 1;
    text-align: CENTER
}

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

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

#flight-pass .ae-content .white-panel&gt;* {
    text-align: left
}

#tour-packages {
    position: relative;
    margin-top: 4em
}

#tour-packages img.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;
    flex: 50%
}

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

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

#tour-packages .tile img {
    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
}

.hub-template .nav.nav-tabs li.tab a {
    display: flex;
    flex-direction: column;
    font-weight: 400;
    align-items: center;
    padding: 10px;
    height: 100%;
    box-shadow: 0 9px 12px -3px rgb(0 0 0/12%);
    justify-content: center;
    font-size: 18px;
    color: #000!important
}

.bottom li.active a {
    border-bottom: none!important
}

.bottom li {
    max-height: 100%;
    height: 200px;
    margin: 0-1px
}

.bottom a {
    padding: 0!important
}

.bottom {
    margin-top: 80px
}

.bottom :focus {
    outline-style: none!important
}

#bottom-content {
    text-align: center
}

#bottom-content .tab-pane {
    padding: 0
}

.bottom .active span {
    -webkit-box-shadow: 0 4px 12px 0 rgb(0 0 0/20%);
    box-shadow: 0 4px 12px 0 rgb(0 0 0/20%);
    background: linear-gradient(180deg,#005078 17%,#fff 17%);
    width: 100%;
    padding: 1em
}

.bottom li a:hover {
    border: 0!important
}

.bottom li.tab a {
    padding: 0!important
}

.copy a {
    align-items: flex-end;
    width: 100%;
    margin-top: auto
}

.map {
    margin-top: 4em
}

.map img {
    display: block;
    margin-left: auto;
    margin-right: auto
}

#formulaire+p {
    text-align: center!important;
    font-size: 12px!important;
    font-weight: 400!important
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

span.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
}

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

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

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

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

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

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

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

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

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

#tour-packages .item-container .item h3,.hub-template.usa #explore #themes .row.white-panel div.col-50 p {
    text-align: left
}

#flight-pass .item-container {
    display: flex;
    flex-direction: column;
    margin: 0 8em
}

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

#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
}

#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
}

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

.hub-template:not(.seat-sale) {
    margin: 25px 0 0
}

#travel-perks .item-container,.cabin-container {
    display: flex
}

#travel-perks .item-container .item {
    padding: 20px;
    flex: 1;
    display: flex;
    flex-direction: column;
    align-content: center;
    text-align: center
}

#travel-perks .item-container .item h3,.cabin-container .item h3 {
    font-weight: 700
}

#travel-perks .item-container .item p:last-child,.cabin-container .item p:last-child {
    margin-top: auto
}

#travel-perks .item-container .item img {
    width: 110px;
    height: 110px;
    margin: 0 auto
}

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

#travel-perks .ae-content {
    padding-top: 8em
}

#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 .item ul li {
    margin-bottom: 7px;
    font-size: 15px!important;
}

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

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

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

#mll .ae-carousel {
    margin: 30px auto 0;
    padding: 0 20px 60px;
    background: #fff
}
#mll ul.slick-dots {
    bottom: 15px;
}

.destination-container {
    display: flex;
    flex-wrap: wrap
}

.destination-container .item {
    flex: 21.5%!important;
    text-align: center!important;
    margin: 15px!important;
    box-shadow: 0 0 15px -3px rgb(0 0 0 / 20%)!important;
    padding: 0px!important;
    background: #fff!important;
}

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

.destination-container .item p.booking-mask-popup {
    margin: 0 auto
}

.destination-container .item p+p,.hub-template .row.box .bottom.row .promotional-code p .promo strong {
    font-size: 14px
}

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

.hub-template .gradient-clouds-bg,.hub-template h2.gradient-clouds-bg {
    padding: 50px 21em 50px 23em;
    font-size: 16px;
    font-weight: 400;
    line-height: 24px;
    width: 100vw;
    position: relative;
    left: calc(-50vw + 50%);
    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;
    margin-top: 55px
}

.hub-template .gradient-clouds-bg+.ae-content,.hub-template h2.gradient-clouds-bg+.ae-content {
    margin-top: -13em
}

.hub-template #all-destinations .gradient-clouds-bg+.ae-content {
    margin-top: -10em
}

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

.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,.slick-next:before,.slick-prev:before {
    display: none
}

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

#all-destinations .ae-content {
    padding-bottom: 0
}

#comfort .gradient-clouds-bg {
    margin-top: 0
}

#earn-bonus-points .ae-content {
    padding-bottom: 0
}

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

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

.mobile-content {
    display: none!important
}

.gradient-clouds-bg .col-50:nth-child(3) {
    -webkit-box-shadow: 0 6px 19px -7px rgb(0 0 0/15%);
    box-shadow: 0 6px 19px -7px rgb(0 0 0/15%);
    background: #fff;
    padding: 30px 40px;
    position: relative;
    left: calc(9% - 7px)
}

.covid-box {
    max-width: 1200px
}

#comfort,#explore {
    padding-top: 0
}

#explore .gradient-clouds-bg {
    margin-top: 0;
    background: linear-gradient(180deg,#ddedf9 40%,#ffff 60%)
}

.nav-tabs-explore li {
    flex: 25%
}

.nav-tabs-explore {
    display: flex;
    height: 240px;
    text-align: center
}

.nav-tabs-explore li.active a {
    background: #fff;
    padding: 20px 0;
    border-bottom: solid 3px #005078
}

.nav-tabs-explore&gt;li.active&gt;a:focus,.nav-tabs-explore&gt;li.active&gt;a:hover {
    background: #fff
}

.nav-tabs-explore&gt;li&gt;a:focus,.nav-tabs-explore&gt;li&gt;a:hover {
    background-color: transparent
}

.copy,.top .col-50 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column
}

.copy {
    padding: 0 30px 30px;
    height: 100%;
    background: #fff
}

.top .col-50 {
    width: 100%;
    max-width: 569px;
    -webkit-box-shadow: 0 4px 12px 0 rgb(0 0 0/20%);
    box-shadow: 0 4px 12px 0 rgb(0 0 0/20%);
    margin: 30px 38px 30px 16px;
    text-align: left;
    display: block;
    background-color: #fff
}

.row.top {
    display: flex;
    flex-wrap: wrap;
    justify-content: center
}

#explore .carousel,.hub-template .row.box h2:after {
    display: none
}

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

    .hub-template .ae-header .hero-image {
        padding-left: 0!important;
        margin: 0 auto 10em
    }

    .tc-panel-container {
        margin-top: 0!important
    }

    .hub-template.usa .boats-bg {
        margin-bottom: 6em
    }
}

@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)
    }

    .hub-template .header-row {
        justify-content: end
    }

    .hub-template .ae-header .hero-image {
        margin: 0 auto 10em
    }

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

@media only screen and (max-width:1200px) and (min-width:768px) {
    #explore .gradient-clouds-bg {
        padding: 50px 6px 50px 20px
    }

    .top .col-50 {
        margin: 30px 14px 30px 16px
    }

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

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

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

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

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

    #advance-seat-selection .row .col-50,#earn-bonus-points .row .col-50,#earn-bonus-points .row .col-50.white-panel {
        width: 100%
    }

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

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

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

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

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

    #flight-pass {
        margin-top: 0
    }

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

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

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

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

    .destination-container .item img {
        height: 140px
    }

    #flight-pass .item-container .item .fp-image {
        height: 350px;
        width: 300%
    }

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

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

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

    .hub-template:not(.seat-sale) {
        padding-top: 50px
    }

    .hub-template.usa {
        padding-top: 0
    }

    :lang(fr) .hub-template:not(.usa) {
        padding-top: 80px
    }

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

    .hub-template .ae-content.top {
        margin-top: -200px;
    }

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

    .InteractiveMap {
        margin: 0-30px;
    }

    .hub-template .nav.nav-tabs {
        display: flex;
        justify-content: center;
    }

    .hub-template .nav.nav-tabs li {
        flex: 0 1 25%
    }
}

@media only screen and (max-width:1024px) and (min-width:768px) {
    .hub-template .ae-header .hero-image {
        padding-left: 2em;
        width: 100%;
        height: 350px
    }

    .hub-template .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
    }

    .hub-template.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
    }

    .hub-template.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
    }

    .hub-template.usa .ae-header .hero-image {
        background: url(/content/dam/aircanada/airtrfx/images/campaigns/usa/hero-thailand-tablet.png)no-repeat right center;
        background-size: cover;
        height: 512px
    }

    .hub-template.usa.japan .ae-header .hero-image {
        background: url(/content/dam/aircanada/airtrfx/images/campaigns/japan/11801546_AC-Japan-Destination_Carousel_772x460.jpg)no-repeat right center;
        background-size: cover;
        height: 512px
    }

    .hub-template.usa .boats-bg {
        background: url(/content/dam/aircanada/airtrfx/images/campaigns/usa/boats-bg-tablet.png)no-repeat center center;
        background-size: cover;
        height: 370px
    }

    div#themes .ae-content {
        padding: 0 40px
    }

    .hub-template:not(.seat-sale) {
        margin-top: 6.5em!important
    }

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

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

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

    #earn-bonus-points p.grey-bg {
        margin-left: 20%
    }

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

    #earn-bonus-points .row .col-50 .item {
        width: 80%;
        padding-left: 20%
    }

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

    .hub-template .grey-bg .ae-content p:first-child {
        border-left: none
    }

    .hub-template .grey-bg .ae-content p:last-child {
        border-right: none
    }

    .hub-template .grey-bg .ae-content {
        padding: 0
    }

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

    .hub-template .nav.nav-tabs {
        display: none;
        align-items: baseline
    }

    .nav.bottom {
        display: flex!important;
        width: auto!important;
        position: relative!important;
        margin: auto!important;
        flex-direction: row!important
    }

    .hub-template .nav.nav-tabs li {
        flex: 25%
    }

    .bottom.nav.nav-tabs li {
        padding: 2em 0 0
    }

    .hub-template .nav.nav-tabs li.tab a {
        justify-content: flex-end
    }

    .hub-template .nav.nav-tabs li img {
        max-width: 100%
    }

    .bottom .nav.nav-tabs li:nth-child(1) img,.bottom .nav.nav-tabs li:nth-child(5) {
        position: relative
    }

    .bottom .nav.nav-tabs li:nth-child(1) a,.bottom .nav.nav-tabs li:nth-child(5) a {
        top: 24px
    }

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

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

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

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

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

    .mobile-content {
        display: flex!important;
        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
    }

    .mobile-content span.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
    }

    .hub-template .nav.nav-tabs.is-open {
        display: block;
        flex-direction: column;
        width: 100%;
        margin: 0 auto;
        position: absolute;
        z-index: 10;
        background: #fff
    }

    .hub-template .nav.nav-tabs.is-open li {
        display: flex;
        font-size: 16px;
        width: 100%
    }

    .bottom.nav.nav-tabs.is-open li a,.hub-template .nav.nav-tabs.is-open li a {
        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
    }

    .bottom.nav.nav-tabs.is-open li a {
        flex-direction: column!important;
        align-items: flex-start;
        justify-content: flex-end
    }

    .bottom span {
        width: 100%;
        padding: 1em;
        height: 100px!important;
        text-align: center;
        font-size: 16px;
        font-weight: 700
    }

    .hub-template .nav.nav-tabs.is-open li a img {
        margin: 0 10px 0 0;
        width: 17px
    }

    ul li span {
        display: block;
        overflow-y: hidden
    }

    .bottom.nav.nav-tabs.is-open li a img,.hub-template .text18,.hub-template h2,.hub-template h2+p {
        width: 100%
    }
}

@media only screen and (max-width:767px) {
    #comfort .gradient-clouds-bg {
        margin-top: 1px
    }

    .top .col-50 {
        margin: 33px
    }

    .desktop-content,.hub-template .nav.nav-tabs li.active a:after,.hub-template .nav.nav-tabs li.active:after {
        display: none
    }

    .mobile-content {
        display: flex!important
    }

    #explore .carousel {
        display: block;
        background-color: transparent
    }

    .hub-template h1 {
        font-size: 32px;
        line-height: 1.12;
        margin-bottom: 10px
    }

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

    .hub-template .h2-like {
        font-size: 24px;
        margin: 25px auto;
        width: 95%
    }

    .hub-template h3 {
        font-size: 16px;
        font-weight: 700
    }

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

    a.backTop {
        margin-top: 4em
    }

    .hub-template .sun-promo-box .sections:nth-of-type(2) {
        flex-direction: column;
        padding: 10px 0
    }

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

    .hub-template .ae-content {
        padding: 2em 20px
    }

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

    .hub-template .header-row {
        background: 0 0;
        height: auto
    }

    .highlight svg {
        width: 24px
    }

    .hub-template .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
    }

    .hub-template.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
    }

    .hub-template.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
    }

    .hub-template.usa .ae-header .hero-image {
        background: url(/content/dam/aircanada/airtrfx/images/campaigns/usa/hero-thailand-mobile.png)no-repeat right center;
        background-size: cover;
        height: 280px;
        width: 100%
    }

    .hub-template.usa .boats-bg {
        background: url(/content/dam/aircanada/airtrfx/images/campaigns/usa/boats-bg-mobile.png)no-repeat center center;
        background-size: cover;
        height: 370px
    }

    div#tab-container {
        margin: 0
    }

    .hub-template .ae-content#top {
        margin: -60px auto 0;
        width: calc(100% - 40px);
        padding: 0 20px
    }

    .hub-template .ae-content#top .h2-like,.hub-template .ae-content#top h2+p:not(.booking-mask-popup) {
        width: 100%
    }

    /*.hub-template #featured-fares {
        height: 500px
    }*/

    .module-row.module-row--em-cmp-lib-airmodules__fare-carousel-with-filters--ac {
        margin-top: -31em
    }

    #travel-perks .ae-content {
        padding: 0
    }

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

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

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

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

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

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

    .hub-template .gradient-clouds-bg+.ae-content,.hub-template h2.gradient-clouds-bg+.ae-content {
        margin-top: -6em
    }

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

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

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

    #mll {
        margin: 0 20px
    }

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

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

    .hub-template button.slick-next,.hub-template button.slick-next:hover {
        transform: rotate(180deg)!important;
    }

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

    #earn-bonus-points .row .col-50 .item {
        margin: 12.5px auto
    }

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

    #tc-panel-container-seat,.tc-panel-container,.tc-panel-content {
        width: calc(100% - 60px);
        margin: auto;
        display: block;
        padding-top: 10px
    }

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

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

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

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

    #flight-pass {
        margin-top: 0
    }

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

    #flight-pass .ae-content .description,#flight-pass .item-container .item,section#aeroplan-offer .ae-row {
        flex-direction: column
    }

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

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

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

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

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

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

    .hub-template .grey-bg .ae-content p:first-child {
        border-left: none
    }

    .hub-template .grey-bg .ae-content p:last-child {
        border-right: none
    }

    .hub-template .grey-bg .ae-content {
        padding: 0
    }

    .blue-bg .ae-content nav .nav-tabs li a,.bouns p {
        text-align: center
    }

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

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

    .hub-template .nav.nav-tabs {
        display: flex;
        flex-wrap: wrap
    }

    .hub-template .nav.nav-tabs li {
        flex: 50%
    }

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

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

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

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

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

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

    #tour-packages .tile {
        flex-direction: column
    }

    .hub-template .nav.nav-tabs li img {
        max-width: 100%
    }

    .hub-template p.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
    }

    .hub-template .nav.nav-tabs.is-open li.active,.hub-template .nav.nav-tabs.is-open li:hover,.hub-template .nav.nav-tabs.is-open ul li:active,p.mobile-content:hover {
        cursor: pointer
    }

    p.mobile-content span.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.dropdown {
        transform: rotateZ(180deg)
    }
    .hub-template .nav.nav-tabs {display: none;}
    .hub-template .nav.nav-tabs.is-open li.active a:after {
        display: none;
        margin: 0 0 0 auto !important;
    }
    .hub-template .nav.nav-tabs.is-open li.active:after {display: none;}

    .hub-template .nav.nav-tabs.is-open {
        display: block;
        flex-direction: column;
        width: 100%;
        margin: 0 auto;
        position: absolute;
        z-index: 10;
        background: #fff
    }

    .hub-template .nav.nav-tabs.is-open li {
        display: flex;
        font-size: 16px;
        width: 100%
    }

    .hub-template .nav.nav-tabs.is-open li a {
        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
    }

    .hub-template .nav.nav-tabs.is-open li a img {
        margin: 0 10px 0 0;
        width: 17px
    }

    #earn-bonus-points p.grey-bg {
        margin-bottom: 40px
    }

    #offers .bouns p {
        text-align: center!important
    }

    #offers p:not(:where([data-em-cmp="price_widget"] *)):nth-child(1),#offers p:not(:where([data-em-cmp="price_widget"] *)):nth-child(2) {
        padding: 10px!important
    }

    .hub-template .gradient-clouds-bg,.hub-template h2.gradient-clouds-bg {
        padding: 50px 10px
    }

    .bouns {
        flex-direction: column!important;
        align-items: center
    }

    .bouns span {
        display: block
    }

    .gradient-clouds-bg .col-50:nth-child(3) {
        left: 0
    }

    #explore.slick-initialized .slick-slide {
        text-align: center
    }

    #explore .slick-slide article .col-xs-12:nth-child(2) {
        text-align: left;
        margin-top: 50px
    }

    #explore ul.slick-dots {
        position: relative;
        top: 10px;
        margin-bottom: 10px
    }

    #explore .slick-slide article .col-xs-12:nth-child(1) {
        background: #fff;
        -webkit-box-shadow: 0 6px 32px -19px rgb(0 0 0/30%),0 7px 16px -8px rgb(0 0 0/10%);
        box-shadow: 1px 1px 6px 0 rgb(0 0 0/30%),0 7px 16px -8px rgb(0 0 0/10%);
        padding: 0
    }

    #explore .slick-slide article .col-xs-12:nth-child(1) p {
        padding: 48px 20px;
        font-size: 16px!important;
        font-weight: 600;
        line-height: 24px;
        text-align: center
    }

    #explore .slick-slide article {
        margin: 0
    }

    #explore .slick-initialized .slick-slide {
        display: block;
        margin: 0 2em
    }

    .hub-template .row.box #offset-ht p.block-align {
        margin-left: 0;
        padding-left: 0!important
    }

    #offers&gt;div.row.box&gt;div.bottom.row&gt;div.col-lg-8.col-md-8.col-sm-8.col-xs-12 {
        height: 0
    }
}

@media only screen and (max-width:767px) and (min-width:415px) {
    .hub-template .ae-header .hero-image {
        height: 350px
    }
}

@media only screen and (max-width:414px) {
    .hub-template .ae-header .hero-image {
        height: 250px
    }

    .hub-template .row.box #offset-ht p.block-align {
        margin-left: 0;
        padding-left: 0!important
    }

    #offers&gt;div.row.box&gt;div.bottom.row&gt;div.col-lg-8.col-md-8.col-sm-8.col-xs-12 {
        height: 0
    }
}

@media only screen and (max-width:1400px) and (min-width:1205px) {
    #explore .gradient-clouds-bg {
        padding: 50px 0
    }

    #comfort .gradient-clouds-bg {
        padding: 50px 97px 50px 133px
    }
}

@media only screen and (min-width:767px) and (max-width:1204px) {
    #explore .gradient-blue-bg,.hub-template .gradient-clouds-bg {
        padding: 50px 0;
        left: 0;
        text-align: center
    }

    #comfort .gradient-blue-bg {
        padding: 50px 20px
    }

    .gradient-blue-bg .col-50:nth-child(3) {
        left: 0
    }

    .cabin-container {
        flex-direction: row;
        text-align: left;
        flex-wrap: wrap
    }

    .cabin-container .item {
        padding: 5px 10px
    }

    .cabin-container img {
        width: 100%;
        max-width: 100%;
        margin: 20px auto
    }

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

    div#comfort .ae-content .h2-like {
        margin: 0 auto 30px!important
    }
}

#offers p {
    text-align: center;
    font-size: 18px;
    font-weight: 400
}

.bouns {
    display: flex;
    text-align: left;
    gap: 20px;
    margin: 20px 0
}

.bouns img {
    max-width: 80px;
    max-height: 80px;
    width: 100%;
    height: 100%
}

#offers .bouns p {
    text-align: left;
    font-size: 14px!important;
    padding: 0!important
}

.bouns p:nth-child(1) {
    font-size: 20px!important;
    font-weight: 700!important
}

.bouns span {
    font-size: 36px!important;
    font-weight: 700!important;
    color: #005078
}

.gradient-clouds-bg .col-50:nth-child(3) p {
    text-align: left!important;
    font-size: 20px!important;
    font-weight: 600!important
}

div#acDbaasRegisterForm {
    margin-top: 20px
}

form#formulaire {
    margin: 50px 0
}

input#acDbaasAeroplanNumber {
    background-color: #fff;
    border-bottom: 1px solid #d0d0ce;
    color: #737373;
    font-size: 16px;
    padding-left: 0;
    border-top: none;
    border-left: none;
    border-right: none;
    box-shadow: none;
    border-radius: 0;
    margin-bottom: 2em
}

input#acDbaasSubmit {
    width: 100%;
    max-width: 306px;
    margin: 24px auto
}

.container {
    max-width: 1200px;
    width: 100%
}

.highlight {
    background: #f5f5f5;
    display: flex;
    gap: 10px;
    padding: 20px
}

.highlight p {
    text-align: left!important;
    font-size: 14px!important;
    padding: 0!important
}

.gradient-clouds-bg .col-50 {
    width: 100%;
    max-width: 540px;
    margin-top: 40px
}

.hub-template.usa #explore #themes .row.white-panel {
    padding: 0;
    margin: 30px 0;
    display: flex;
    background-color: #fff;
    box-shadow: 0 0 7px -3px rgb(84 84 84/75%)
}

.hub-template.usa #explore #themes .row.white-panel img.col-50 {
    max-height: 300px;
    width: 50%;
    max-width: 50%;
    object-fit: cover;
    flex: 0 0 50%
}

@media only screen and (min-width:768px) and (max-width:1024px) {
    .hub-template.usa #explore #themes .row.white-panel img.col-50 {
        max-height: none;
        min-height: 200px;
        width: auto;
        max-width: 50%;
        object-fit: cover
    }

    .cabin-container .item,.cabin-container .item:nth-of-type(2) {
        max-width: 700px;
        margin: 10px auto
    }

    /*.hub-template #featured-fares {
        height: 500px
    }*/

    .module-row.module-row--em-cmp-lib-airmodules__fare-carousel-with-filters--ac {
        margin-top: -30em
    }

    .hub-template .ae-content#top {
        margin: -80px auto 0;
        width: calc(100% - 40px)
    }
}

@media only screen and (max-width:767px) {
    .hub-template.usa #explore #themes .row.white-panel {
        flex-direction: column
    }

    .hub-template.usa #explore #themes .row.white-panel:nth-of-type(even) {
        flex-direction: column-reverse
    }
    .hub-template.usa #explore #themes .row.newyork {
        flex-direction: column-reverse
    }

    .hub-template.usa #explore #themes .row.white-panel img.col-50 {
        max-height: 260px;
        min-height: 100px;
        width: auto;
        max-width: 100%;
        object-fit: cover;
        object-position: top;
        flex: none
    }

    .hub-template .text18,.hub-template h2+p:not(.booking-mask-popup) {
        width: 90%
    }
}

#offers p:not(:where([data-em-cmp="price_widget"] *)):nth-child(1),#offers p:not(:where([data-em-cmp="price_widget"] *)):nth-child(2) {
    padding: 0 9em
}

.usa #offers p:not(:where([data-em-cmp="price_widget"] *)):nth-child(1),.usa #offers p:not(:where([data-em-cmp="price_widget"] *)):nth-child(2),.gradient-cloud-bg p:nth-child(1),.gradient-cloud-bg p:nth-child(2) {
    padding: 0
}

.gradient-clouds-bg p:nth-child(1) {
    padding: 0!important
}

.highlight svg {
    width: 24px
}

.covid-box p {
    padding: 0!important;
    font-size: 16px!important;
    text-align: left!important;
    font-weight: 400
}

@media only screen and (min-width:2500px) {
    .hub-template .gradient-clouds-bg,.hub-template h2.gradient-clouds-bg {
        padding: 50px 35em 50px 42em
    }

    .bottom {
        margin: 80px 7em 80px 1em
    }

    .top .col-50 {
        margin: 30px 111px 30px 16px
    }

    .map img {
        margin: 0 1em
    }

    #comfort .gradient-clouds-bg {
        padding: 50px 40em 50px 43em
    }
}

.hub-template .row.box #offset-ht p {
    padding: 0;
    font-size: 14px;
    text-align: left!important;
    width: 100%;
    margin-bottom: 15px
}

.hub-template .row.box #offset-ht p.block-align {
    padding-right: 20px
}

.hub-template .tc-panel-content p {
    width: 100%;
    text-align: left!important;
    padding: 0!important;
    font-size: 14px!important
}

.hub-template .row.box {
    margin-top: 70px
}</pre></body></html>