html {
    background: linear-gradient(10deg, #2B9EDB 0%, #014EAA 82%, #014EAA 100%) !important;
    min-height: 100%;
}

body {
    background: transparent !important;
    min-height: 100%;
}

/* Header Adjustments for Destination Québec Page */
.site-header {
    background-color: rgba(1, 78, 170, 0.95) !important; /* Matches top of gradient #014EAA */
    border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

.site-header .main-nav a {
    color: #FFFFFF !important;
}

.quebec-page-wrapper {
    position: relative;
    width: 100%;
    min-width: 1728px;
    background: transparent;
    overflow-x: hidden;
}

.quebec-layout-container {
    position: relative;
    width: 1728px;
    height: 5421px;
    margin: 0 auto;
}

/* fond page- destination québec */
.quebec-bg-gradient {
    position: absolute;
    width: 1728px;
    height: 3839px;
    left: 0px;
    top: 0px;
    background: transparent;
    z-index: 0;
}

/* Destination québec inner content container */
.quebec-content-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 0px;
    gap: 94px;
    position: absolute;
    width: 1730px;
    height: 5386.66px;
    left: -1px;
    top: 0px;
    z-index: 1;
}

/* Hero section */
.quebec-hero {
    position: relative;
    width: 1730px;
    height: 882px;
}

.quebec-banner {
    position: absolute;
    width: 1729px;
    height: 916px;
    left: 0px;
    top: 0px;
}

.quebec-banner-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Panneaux */
.quebec-panneaux-villes {
    position: absolute;
    width: 1730px;
    height: 882px;
    left: 0px;
    top: 0px;
}

.quebec-sign {
    box-sizing: border-box;
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    padding: 0px 24px 0px 10px;
    position: absolute;
    height: 84px;
    border: 7.2px solid #FFFFFF;
    border-radius: 19px;
    box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.15);
    transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275), box-shadow 0.3s ease;
    z-index: 2;
}

.quebec-panneaux-villes .quebec-sign:hover {
    box-shadow: 0px 8px 20px rgba(0, 0, 0, 0.25);
}

.quebec-arrow {
    width: 60px;
    height: 60px;
    display: block;
    object-fit: contain;
    transition: transform 0.3s ease;
}

.quebec-sign:hover .quebec-arrow {
    transform: translateX(8px);
}

.quebec-sign-text {
    font-family: 'Effra', 'Source Code Pro', monospace;
    font-style: normal;
    font-weight: 700;
    font-size: 38px;
    line-height: 46px;
    text-transform: uppercase;
    color: #FFFFFF;
    white-space: nowrap;
}

/* Individual sign properties */
.quebec-panneaux-villes .quebec-sign {
    cursor: pointer;
}

.quebec-sign.montreal {
    width: 400px;
    left: 780px;
    top: 134px;
    background: #F83D00;
    transform: rotate(-3.83deg);
    animation: float-montreal 4s ease-in-out infinite;
}

.quebec-sign.montreal:hover {
    transform: rotate(-3.83deg) scale(1.05);
    animation: none;
}

.quebec-sign.quebec-city {
    width: 437px;
    left: 1048px;
    top: 283px;
    background: #00C270;
    transform: rotate(0.86deg);
    animation: float-quebec 4.5s ease-in-out infinite;
}

.quebec-sign.quebec-city:hover {
    transform: rotate(0.86deg) scale(1.05);
    animation: none;
}

.quebec-sign.gatineau {
    width: 405px;
    left: 611px;
    top: 275px;
    background: #49D9FF;
    transform: rotate(-2.04deg);
    animation: float-gatineau 4.2s ease-in-out infinite;
}

.quebec-sign.gatineau:hover {
    transform: rotate(-2.04deg) scale(1.05);
    animation: none;
}

.quebec-sign.sherbrooke {
    width: 386px;
    left: 920px;
    top: 415px;
    background: #0075DC;
    transform: rotate(1.31deg);
    animation: float-sherbrooke 4.8s ease-in-out infinite;
}

.quebec-sign.sherbrooke:hover {
    transform: rotate(1.31deg) scale(1.05);
    animation: none;
}

/* Float keyframes for each city sign to preserve its unique rotation angle */
@keyframes float-montreal {
    0%, 100% { transform: rotate(-3.83deg) translateY(0); }
    50% { transform: rotate(-3.83deg) translateY(-8px); }
}

@keyframes float-quebec {
    0%, 100% { transform: rotate(0.86deg) translateY(0); }
    50% { transform: rotate(0.86deg) translateY(-8px); }
}

@keyframes float-gatineau {
    0%, 100% { transform: rotate(-2.04deg) translateY(0); }
    50% { transform: rotate(-2.04deg) translateY(-8px); }
}

@keyframes float-sherbrooke {
    0%, 100% { transform: rotate(1.31deg) translateY(0); }
    50% { transform: rotate(1.31deg) translateY(-8px); }
}

/* Descriptif Container */
.quebec-descriptif-container {
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    align-items: center;
    padding: 25px 17px;
    gap: 10px;
    position: absolute;
    width: 1064px;
    height: 237px;
    left: 331px;
    top: 535px;
    background: url('../05- Destination Québec/hero/Descriptif.webp') no-repeat center/contain !important;
    border: none;
    box-sizing: border-box;
    cursor: pointer;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    z-index: 1;
}


.quebec-descriptif-text {
    width: 1030px;
    height: 176px;
    font-family: 'Source Code Pro', monospace;
    font-style: normal;
    font-weight: 400;
    font-size: 14px;
    line-height: 18px;
    color: #101010;
    margin: 0;
    text-align: left;
}

.quebec-descriptif-text strong {
    font-weight: 600;
}

.bouton-tout-voir {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    padding: 0px;
    width: 22px;
    height: 13px;
    flex: none;
    order: 1;
    flex-grow: 0;
    transition: transform 0.3s ease, filter 0.3s ease;
}

.quebec-descriptif-container:hover .bouton-tout-voir {
    transform: translateY(8px);
    filter: invert(53%) sepia(0%) saturate(0%) brightness(90%) contrast(85%);
}

.fluent-ios-arrow-24-regular {
    margin: 0 auto;
    width: 22px;
    height: 13px;
    transform: none;
}

.fluent-ios-arrow-24-regular img {
    width: 22px;
    height: 13px;
    display: block;
}

/* GRID LIST SECTION */
.quebec-grid-section {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 0px;
    gap: 34px;
    width: 1671px;
    height: 4410.66px;
}

.queb-card {
    position: relative;
    box-sizing: border-box;
    overflow: hidden;
    background: #EAEAEA;
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.08);
}

.queb-card-bg {
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

/* Block 1: Metro */
.quebec-list-block.block1 {
    position: relative;
    width: 1671px;
    height: 1237.66px;
    flex: none;
    order: 0;
    flex-grow: 0;
}

.quebec-images-row1 {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    padding: 0px;
    width: 1671px;
    height: 592px;
}

.quebec-mockup-metro {
    width: 918.03px;
    height: 591.66px;
}

.quebec-affiche-metro {
    width: 753px;
    height: 592px;
}

.quebec-mockup-metro-2 {
    position: absolute;
    width: 1141px;
    height: 646px;
    left: 265px;
    top: 592px;
}

.quebec-sign.dans-le-metro {
    position: absolute;
    width: 444.87px;
    height: 93.16px;
    left: 236px;
    top: 592px;
    background: #F83D00;
    transform: rotate(-3.83deg);
    z-index: 5;
}


/* Block 2: Billet & Badges */
.quebec-list-block.block2 {
    position: relative;
    width: 1671px;
    height: 983px;
    flex: none;
    order: 1;
    flex-grow: 0;
    margin-top: 120px;
}

.quebec-images-row2 {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-start;
    padding: 0px;
    position: absolute;
    height: 621px;
    left: 0px;
    right: 0px;
    top: 90px;
}

.quebec-mockup-billet {
    width: 755px;
    height: 490px;
}

.quebec-guide {
    width: 910px;
    height: 621px;
}

.quebec-carousel {
    position: absolute;
    width: 753.23px;
    height: 378px;
    left: 262px;
    top: 580px;
}

.quebec-mockup-badge {
    position: absolute;
    width: 719.58px;
    height: 474.55px;
    left: 690px;
    top: 379px;
    transform: rotate(13.72deg);
    z-index: 10;
    background: transparent !important;
    box-shadow: none !important;
}

.quebec-mockup-badge .queb-card-bg {
    background-size: contain;
}

.quebec-sign.communication {
    position: absolute;
    width: 486.42px;
    height: 93.16px;
    left: 591px;
    top: 29px;
    background: #00C270;
    transform: rotate(1.76deg);
    z-index: 12;
}


/* Block 3: Programme & Scenography */
.quebec-list-block.block3 {
    position: relative;
    width: 1671px;
    height: 1240px;
    flex: none;
    order: 2;
    align-self: stretch;
    flex-grow: 0;
}

.quebec-programme {
    width: 1354px;
    height: 336px;
    margin: 110px auto 0;
}

.quebec-images-row4 {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    padding: 0px;
    width: 1354px;
    height: 589.34px;
    margin: 41px auto 0;
    justify-content: space-between;
}

.quebec-mockup-stand {
    width: 827px;
    height: 587px;
}

.quebec-scenography-row {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 0px;
    width: 527px;
    height: 589.34px;
    gap: 7px;
}

.quebec-cabanes {
    width: 527px;
    height: 291px;
}

.quebec-dome {
    width: 527px;
    height: 298.34px;
}

.quebec-sign.scenographie {
    position: absolute;
    width: 450.42px;
    height: 93.16px;
    left: 796.5px;
    top: 13px;
    background: #49D9FF;
    transform: rotate(-2.04deg);
    z-index: 10;
}


/* Block 4: Mockup Landing Page */
.quebec-list-block.block4 {
    position: relative;
    width: 1671px;
    height: 740px;
    flex: none;
    order: 3;
    align-self: stretch;
    flex-grow: 0;
}

.quebec-mockup-landing {
    position: relative;
    width: 100%;
    height: 740px;
}

.quebec-landing-container {
    position: absolute;
    width: 864px;
    height: 549px;
    left: 403.5px;
    top: 132px;
    z-index: 1;
}

.quebec-mockup-ordi {
    position: absolute;
    width: 1105px;
    height: 647px;
    left: 283px;
    top: 92.87px;
    background-image: url('../04- Myia/mockup-ordi.webp');
    background-size: contain;
    background-repeat: no-repeat;
    z-index: 2;
    pointer-events: none;
}

.quebec-sign.landing-page {
    position: absolute;
    width: 429.42px;
    height: 93.16px;
    left: 869.5px;
    top: -9.13px;
    background: #0075DC;
    box-shadow: 0px -5px 19.3px rgba(0, 0, 0, 0.15);
    transform: rotate(6.44deg);
    z-index: 10;
}


/* RESPONSIVE LAYOUT */
@media (max-width: 1200px) {
    .quebec-page-wrapper {
        min-width: 100%;
    }
    
    .quebec-layout-container {
        width: 100%;
        height: auto;
    }
    
    .quebec-bg-gradient {
        width: 100%;
        height: 100%;
    }
    
    .quebec-content-inner {
        position: relative;
        width: 100%;
        height: auto;
        left: 0;
        top: 0;
        padding: 40px 20px;
        box-sizing: border-box;
        gap: 60px;
    }
    
    .quebec-hero {
        width: 100%;
        height: auto;
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 30px;
    }
    
    .quebec-banner {
        position: relative;
        width: 100%;
        height: auto;
        aspect-ratio: 16/9;
    }
    
    .quebec-panneaux-villes {
        position: relative;
        width: 100%;
        height: auto;
        left: 0;
        top: 0;
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        gap: 20px;
        transform: none;
    }
    
    .quebec-sign {
        position: relative !important;
        left: 0 !important;
        top: 0 !important;
        right: 0 !important;
        width: auto !important;
        transform: none !important;
        margin: 0 !important;
    }
    
    .quebec-sign:hover {
        transform: scale(1.05) !important;
    }
    
    .quebec-descriptif-container {
        position: relative;
        width: 100%;
        max-width: 800px;
        height: auto;
        left: 0;
        top: 0;
        padding: 20px;
    }
    
    .quebec-descriptif-text {
        width: 100%;
        height: auto;
    }
    
    .quebec-grid-section {
        width: 100%;
        height: auto;
        gap: 60px;
    }
    
    .quebec-list-block {
        width: 100% !important;
        height: auto !important;
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 20px;
        margin-top: 0 !important;
    }
    
    .quebec-images-row1, .quebec-images-row2, .quebec-images-row4 {
        flex-direction: column !important;
        width: 100% !important;
        height: auto !important;
        gap: 20px;
        margin: 0 !important;
    }
    
    .queb-card {
        width: 100% !important;
        max-width: 600px;
        height: auto !important;
        aspect-ratio: 4/3;
    }
    
    .quebec-mockup-metro-2 {
        position: relative !important;
        left: 0 !important;
        top: 0 !important;
        width: 100% !important;
        max-width: 600px;
        aspect-ratio: 16/9;
    }
    
    .quebec-carousel {
        position: relative !important;
        left: 0 !important;
        top: 0 !important;
        width: 100% !important;
        max-width: 600px;
        aspect-ratio: 16/9;
    }
    
    .quebec-mockup-badge {
        position: relative !important;
        left: 0 !important;
        top: 0 !important;
        width: 100% !important;
        max-width: 400px;
        transform: none !important;
        aspect-ratio: 4/3;
    }
    
    .quebec-mockup-badge:hover {
        transform: scale(1.05) !important;
    }
    
    .quebec-programme {
        width: 100% !important;
        max-width: 600px;
        aspect-ratio: 16/5;
        height: auto !important;
    }
    
    .quebec-scenography-row {
        width: 100% !important;
        height: auto !important;
        gap: 20px;
    }
    
    .quebec-cabanes, .quebec-dome {
        width: 100% !important;
        height: auto !important;
        aspect-ratio: 16/9;
    }
    
    .quebec-mockup-landing {
        width: 100% !important;
        height: auto !important;
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 20px;
    }
    
    .quebec-mockup-ordi {
        position: relative !important;
        width: 100% !important;
        max-width: 600px;
        height: auto !important;
        aspect-ratio: 16/10;
        left: 0 !important;
        top: 0 !important;
    }
    
    .quebec-landing-container {
        position: absolute !important;
        width: 60% !important;
        height: 60% !important;
        left: 20% !important;
        top: 10% !important;
    }
}
