.Campaign.lg\:max-w-6xl .px-3.py-4 {
    padding: 0;
}

.FlightsBooking.w-full.max-w-full {
    background-color: #F4F4F4;
    max-width: 100%;
}

h1.__pfs.__bss {
    text-align: center;
    font-weight: 700 !important;
    color: #fff !important;
    text-shadow: 0px 0px 15px #000000 !important;
    position: relative;
}

#ww-destinations #olympics-region ul.__pfs.nav.nav-tabs li.__pfs.active a.__pfs {
    color: #1460AA !important;
    font-weight: 700 !important;
    border: 2px solid #1460AA !important;
    border-radius: 14px;
}

.ups-cta {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 60px;
    margin-top: -20px;
}

.ups-button {
    padding: 10px 32px;
    border-radius: 14px;
    background: #005078 !important;
    text-align: center;
    max-width: 157px;
    margin-top: 20px;
}

.ups-button a {
    color: #fff !important;
    font-weight: 600 !important;
}

.ups-button.btn-primary:hover {
    cursor: pointer;
}

.__pfs.ups-card.__bss {
    margin-bottom: 20px;
}

#ww-destinations #olympics-region ul.__pfs.nav.nav-tabs li.__pfs a.__pfs, #ww-destinations #olympics-region ul.__pfs.nav.nav-tabs li.__pfs a.__pfs:hover, #ww-destinations #olympics-region ul.__pfs.nav.nav-tabs li.__pfs a.__pfs:focus {
    background: #fff;
}

.ups-section .ups-card .ups-image {
    margin-bottom: 20px;
}

#top2 {
    position: relative;
}

#top2::before {
    content: "";
    position: absolute;
    top: -60px;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.5) 100%);
    z-index: 0;
}

.__pfs.ups-cards.__bss {
    justify-content: center !important;
}

@media only screen and (max-width: 767px) {
    h1.__pfs.__bss {
        font-size: 24px !important;
        top: -100px !important;
        margin-bottom: 0 !important;
    }

    .flex.flex-wrap.flex-col.max-w-full.relative.justify-start.bg-center.bg-cover.bg-no-repeat.Bh.Bi {
        margin-top: -100px !important;
    }
}

@media only screen and (min-width: 768px) and (max-width: 1024px) {
    h1.__pfs.__bss {
        font-size: 28px;
        margin-bottom: 0;
        top: -100px !important;
    }

    .flex.flex-wrap.flex-col.max-w-full.relative.justify-start.bg-center.bg-cover.bg-no-repeat.Bh.Bi {
        margin-top: -100px !important;
    }

    .__pfs.ups-card.__bss:nth-child(1),
    .__pfs.ups-card.__bss:nth-child(3),
    .__pfs.ups-card.__bss:nth-child(5) {
        border-right: 1px solid #C9CACC;
    }

    .__pfs.ups-card.__bss {
        width: 311px;
    }
}

@media only screen and (min-width: 1025px) {
    h1.__pfs.__bss {
        top: -150px;
        font-size: 48px !important;
    }

    .flex.flex-wrap.flex-col.max-w-full.relative.justify-start.bg-center.bg-cover.bg-no-repeat.Bh.Bi {
        margin-top: -150px;
    }

    .__pfs.ups-card.__bss:nth-child(1),
    .__pfs.ups-card.__bss:nth-child(2),
    .__pfs.ups-card.__bss:nth-child(4),
    .__pfs.ups-card.__bss:nth-child(5) {
        border-right: 1px solid #C9CACC;
    }

    .__pfs.ups-card.__bss {
        width: 340px;
    }
}



article.__psc {
    background-color: #F4F4F4;
}
.Campaign .row.__pfs {
    display: flex;
    flex-wrap: wrap;
    margin: 0 auto !important;
}
#top2 > p {
    text-align: center;
    padding-bottom: 20px;
}
.row.bonus-pts .pt-desc {
    max-width: 85%;
    width: 100%;
    padding-left: 20px;
    padding-top: 20px;
}
.row.bonus-pts .pt-desc h2 {
    font-size: 30px;
    font-weight: 700;
    margin-bottom: 15px;
}
.FareTitleHeader #top2 .dates-container > div {
    display: flex;
}
.FareTitleHeader #top2 .dates-container > div > img {
    padding-right: 15px;
}
.Campaign.lg\:max-w-6xl .exploreFares-container {
    background-color: #F4F4F4;
}
.Campaign.lg\:max-w-6xl div#tc-panel-container {
    background: #F4F4F4 !important;
}
#flightOffers {
    padding: 0 calc((100% - 68rem) / 2);
    padding-bottom: 40px;
}
div#join-aeroplan {
    background-color: white;
    box-shadow: 0px 0px 15px -3px rgba(0, 0, 0, 0.2);
    border-radius: 13px;
    width: 45%;
    padding: 20px 35px;
    min-height: 400px;
}
.__pfs.col-50.how-to.__bss {
    width: 55%;
    padding-right: 125px;
    padding-top: 60px;
}
div#join-aeroplan form#formulaire {
    height: 100%;
}
div#join-aeroplan form#formulaire fieldset {
    height: 100%;
}
div#join-aeroplan form#formulaire fieldset img {
    margin: 0 auto;
    margin-bottom: 30px;
}
div#join-aeroplan form#formulaire fieldset h3#name-label {
    margin-top: 30px;
    margin-bottom: 30px;
    text-align: center;
    font-weight: 600;
    font-size: 20px;
}
div#join-aeroplan form#formulaire fieldset input#acDbaasAeroplanNumber {
    border: none;
    border-bottom: 1px solid #dadada;
    border-radius: 0;
    padding: 20px 10px;
    box-shadow: none;
    margin-bottom: 30px;
}
div#join-aeroplan form#formulaire fieldset input#acDbaasSubmit {
    background-color: #005078;
    border-radius: 30px;
    padding: 15px;
    min-width: 300px;
    margin: 0 auto;
    margin-bottom: 30px;
    margin-top: 30px;
}
div#join-aeroplan form#formulaire fieldset .conditional {
    text-align: center;
}
div#acDbaasRegistered {
    text-align: center;
}
.__pfs.col-50.how-to.__bss h2 {
    font-size: 28px;
    font-weight: 700;
}
.__pfs.col-50.how-to.__bss ul {
    list-style-type: none;
    padding: 0;
    margin-top: 30px;
}
.__pfs.col-50.how-to.__bss ul li > div p {
    margin-bottom: 0;
}
.__pfs.col-50.how-to.__bss ul li {
    display: flex;
    flex-direction: row;
    align-items: center;
    flex-wrap: nowrap;
    padding: 7px 0;
}
.__pfs.col-50.how-to.__bss ul li img {
    margin-right: 20px;
}
div span a.__pfs.__bss::after{
    display: none;
}
.acv-promo {
    display: flex;
    flex-direction: row;
    align-items: stretch;
    width: 1150px;
    margin: 0 auto;
    background-color: #ffffff;
    box-shadow: 0px 6px 19px -7px rgba(0, 0, 0, 0.15);
    border-radius: 13px;
    overflow: hidden;
    padding: 30px;
    margin-bottom: 50px;
}
.acv-promo img {
    max-width: 340px;
    border-radius: 18px;
}
.acv-promo .promo-desc {
    background-color: white;
    padding: 20px;
    padding-top: 0;
    position: relative;
}
.acv-promo .promo-desc h2.__pfs.__bss {
    font-size: 28px;
    font-weight: 700;
    line-height: 33px;
    margin-bottom: 20px;
}
.acv-promo .promo-desc .acv-promo .promo-desc p.__pfs.__bss {
    font-size: 18px;
}
.acv-promo > div.promo-desc > p:nth-child(3) {
    text-align: right;
}
.acv-promo .promo-desc p a {
    color: white;
    background-color: #005078;
    text-decoration: none;
    padding: 9px 60px;
    font-weight: 600;
    border-radius: 46px;
    position: absolute;
    right: 0;
    bottom: 0;
}
.acv-promo .promo-desc p a.__pfs.__bss:visited {
    color: white;
}
.how-to a.__pfs.__bss {
    font-weight: 700;
}
.how-to a.__pfs.__bss:after {
    content: '';
    display: inline-block;
    background: url(https://www.aircanada.com/content/dam/aircanada/loyalty-content/images/prev-arrow.svg) no-repeat center center;
    background-size: 14px 14px;
    width: 14px;
    height: 14px;
    transform: rotate(180deg);
    margin-left: 5px;
    vertical-align: middle;
}
.FareTitleHeader #top2 .dates-container.dates-container-usConfig {
    flex-wrap: wrap;
}
div#olympics-region h2.__pfs.__bss {
    font-size: 28px;
    font-weight: 700;
    padding-bottom: 20px;
}
div#olympics-region h2.__pfs.__bss, div#olympics-region p.__pfs.__bss {
    text-align: center;
}
.__pfs.form-container-standard.form-wrapper.error-check.__bss p {
    color: #d8292f;
    font-weight: 600;
}
label#rules-check {
    margin-left: 10px;
}
.acv-promo .promo-desc p a.__pfs.__bss:hover {
    color: white;
    text-decoration: none;
}
a.__pfs.primary-btn.booking-mask-popup.__bss {
    border-radius: 33px;
}
img.__pfs.giftBox.__bss {
    max-width: 500px;
}
p.__pfs.Av.tracking-normal.b.H.I.J.K.Ds.Dt.__bss a {
    font-size: 12px;
}
.Campaign.lg\:max-w-6xl .exploreFares-container .header-row {
    height: 0;
    padding-top: 0;
    padding-bottom: 0 !important;
}
.Campaign.lg\:max-w-6xl .exploreFares-container p.__pfs, .Campaign.lg\:max-w-6xl .exploreFares-container span.__pfs {
    font-size: 14px;
}
.FareTitleHeader #top2 .dates-container div.__pfs.__bss{
    margin: 0;
}
.__pfs.booking-header-container.__bss h2.__pfs.__bss {
    text-align: center;
    font-size: 24px;
    font-weight: 700;
}
.__pfs.ae-content.match-sale-container.exploreFares-container.__bss {
    max-width: 72rem;
    margin: 0 auto;
}
.ae-content.match-sale-container.exploreFares-container .flash-sale-container.white-panel {
    background-color: white;
    box-shadow: 0px 0px 15px -3px rgba(0, 0, 0, 0.2);
    margin-top: 40px;
}
span.__pfs.ic.travel.__bss,
span.__pfs.ic.code.__bss,
span.__pfs.ic.cabin.__bss,
span.__pfs.ic.destinations.__bss,
span.__pfs.ic.book.__bss,
span.__pfs.ic.no-icon.__bss {
    font-weight: 700;
}
.exploreFares-container.match-sale-container .flash-sale-container .promo-flex-container {
    align-items: center;
}
#ww-destinations ul.__pfs.nav.nav-tabs li.__pfs a.__pfs {
    border-radius: 13px;
    border: 1px solid white;
    font-weight: 600;
    padding: 10px;
}
.Campaign.lg\:max-w-6xl .exploreFares-container .tab-container .nav.nav-tabs li.__pfs a {
    border-radius: 14px;
    border: none;
    box-shadow: 0px 5px 20px -5px rgba(0, 0, 0, 0.2);
    background: #fff;
    padding: 10px;
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 14px;
    font-weight: 700;
    color: #000;
    height: 60px;
    text-align: center;
}
#ww-destinations ul.__pfs.nav.nav-tabs li.__pfs {
    border-bottom: none !important;
    padding-bottom: 5px;
}
#ww-destinations ul.__pfs.nav.nav-tabs li.__pfs.active a.__pfs {
    color: #005078 !important;
    font-weight: 700 !important;
}
#ww-destinations div#olympics-region .tab-content {
    padding-top: 0;
}
.Campaign.lg\:max-w-6xl {
    background-color: #F4F4F4;
}
#ww-destinations #olympics-region ul.__pfs.nav.nav-tabs li.__pfs.active a.__pfs {
    color: #005078 !important;
    font-weight: 700 !important;
    border: 1px solid #005078;
    border-radius: 14px;
}
#ww-destinations #olympics-region ul.__pfs.nav.nav-tabs li.__pfs a.__pfs, 
#ww-destinations #olympics-region ul.__pfs.nav.nav-tabs li.__pfs a.__pfs:hover, 
#ww-destinations #olympics-region ul.__pfs.nav.nav-tabs li.__pfs a.__pfs:focus {
    padding: 10px;
    font-size: 16px;
    font-weight: 600;
    color: #000;
    border: 1px solid white;
    margin: 0;
    border-radius: 14px;
    text-decoration: none !important;
}
#ww-destinations div.__pfs#flightOffers {
    padding-top: 0;
    padding-bottom: 60px;
}
@media screen and (max-width: 768px) {
    #ww-destinations > div.__pfs.row.bonus-pts.__bss {
        flex-direction: column;
        padding: 0;
        width: 93%;
    }
    div.__pfs#tc-panel-container {
        margin: auto !important;
    }
    .row.bonus-pts .pt-desc {
        max-width: 95%;
        width: 100%;
        padding-left: 20px;
        padding-top: 20px;
    }
    #ww-destinations > div.__pfs.row.bonus-pts.__bss > div.__pfs.pt-img.__bss {
        max-width: 50%;
        width: 30%;
        margin: auto;
        padding-top: 20px;
    }
    #top2 > div > div:nth-child(3) > span > sup {
        display: contents;
    }
    .row.bonus-pts .pt-desc h2 {
        font-size: 22px;
        font-weight: unset;
        margin-bottom: 15px;
        text-align: center;
        font-weight: 700;
    }
    #ww-destinations > div.__pfs.row.bonus-pts.__bss > div.__pfs.pt-desc.__bss > p {
        text-align: center;
    }
    .FareTitleHeader #top2 .dates-container {
        flex-direction: column;
    }
    .__pfs.row.ae-flex-container.__bss {
        display: flex;
        flex-direction: column;
    }
    .__pfs.row.ae-flex-container.__bss > div {
        width: 100%;
    }
    .__pfs.col-50.how-to.__bss {
        padding-right: 0;
        padding-top: 0;
        padding: 0 20px;
    }
    div#join-aeroplan {
        width: 93%;
        margin: 0 auto;
        margin-top: 40px;
    }
    .acv-promo {
        flex-direction: column;
        padding: 0;
        width: 93%;
    }
    .acv-promo img {
        max-width: 100%;
        border-radius: 0;
        margin-bottom: 20px;
    }
    .acv-promo .promo-desc h2.__pfs.__bss {
        font-size: 24px;
        line-height: 30px;
    }
    .acv-promo .promo-desc p a {
        position: relative;
        right: unset;
        bottom: unset;
        width: 100%;
        display: inline-block;
    }
    .acv-promo > div.promo-desc > p:nth-child(3) {
        text-align: center;
    }
    .Campaign.lg\:max-w-6xl div#tc-panel-container {
        padding-left: 20px;
        padding-right: 20px;
    }
    div#join-aeroplan form#formulaire fieldset input#acDbaasSubmit {
        min-width: 285px;
    }
}
@media screen and (min-width: 769px) and (max-width: 1240px) {
    .FareTitleHeader #top2 .dates-container {
        flex-direction: row;
        flex-wrap: wrap;
    }
    .__pfs.row.ae-flex-container.__bss {
        display: flex;
        flex-direction: column;
        width: 100%;
    }
    .__pfs.row.ae-flex-container.__bss > div {
        width: 100%;
    }
    .__pfs.col-50.how-to.__bss {
        padding-right: 0;
        padding-top: 0;
        padding: 0 20px;
    }
    div#join-aeroplan {
        width: 93%;
        margin: 0 auto;
    }
    .acv-promo {
        flex-direction: row;
        padding: 30px;
        width: 93%;
    }
    .acv-promo > div {
        width: 50%;
    }
    .acv-promo img {
        max-width: 100%;
        border-radius: 13px;
        margin-bottom: 0;
    }
    .acv-promo .promo-desc h2.__pfs.__bss {
        font-size: 24px;
        line-height: 30px;
    }
    .acv-promo .promo-desc p a {
        position: absolute;
        right: unset;
        left: 20px;
        bottom: 20px;
        width: 100%;
        max-width: 300px;
        display: inline-block;
    }
    .acv-promo > div.promo-desc > p:nth-child(3) {
        text-align: center;
    }
    .Campaign.lg\:max-w-6xl div#tc-panel-container {
        max-width: 1024px;
        padding-left: 38px;
        padding-right: 38px;
    }
    html:lang(fr) .acv-promo .promo-desc p a {
        bottom: -10px;
    }
}