/********** Template CSS **********/

:root {
    --bs-primary: #e39a2a;
    --bs-primary-rgb: 227, 154, 42;
    --bs-secondary: #5f5648;
    --bs-secondary-rgb: 95, 86, 72;
    --bs-light: #f8f1e4;
    --bs-light-rgb: 248, 241, 228;
    --bs-dark: #0b0b0b;
    --bs-dark-rgb: 11, 11, 11;
    --bs-white: #fffdf8;
    --bs-white-rgb: 255, 253, 248;
    --lux-gold: #cfa64a;
    --lux-gold-deep: #a87a1f;
    --lux-black: #0b0b0b;
}

body {
    color: #4e453b;
    background-color: #fffdf8;
    background-image:
        radial-gradient(circle at top right, rgba(227, 154, 42, .08), transparent 24%),
        radial-gradient(circle at bottom left, rgba(11, 11, 11, .04), transparent 30%);
}

a {
    color: var(--bs-primary);
}

a:hover {
    color: var(--lux-gold-deep);
}

.bg-primary {
    background-color: var(--bs-primary) !important;
}

.bg-light {
    background-color: var(--bs-light) !important;
}

.bg-dark {
    background-color: var(--bs-dark) !important;
}

.text-primary {
    color: var(--bs-primary) !important;
}

.text-dark {
    color: var(--bs-dark) !important;
}

.border-primary {
    border-color: var(--bs-primary) !important;
}

.btn-primary {
    color: var(--bs-dark);
    background-color: var(--bs-primary);
    border-color: var(--bs-primary);
}

.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active {
    color: var(--bs-white);
    background-color: var(--lux-gold-deep);
    border-color: var(--lux-gold-deep);
}

.btn-outline-primary {
    color: var(--bs-primary);
    border-color: var(--bs-primary);
}

.btn-outline-primary:hover,
.btn-outline-primary:focus,
.btn-outline-primary:active {
    color: var(--bs-dark);
    background-color: var(--bs-primary);
    border-color: var(--bs-primary);
}

.form-control:focus {
    border-color: rgba(var(--bs-primary-rgb), .45);
    box-shadow: 0 0 0 .25rem rgba(var(--bs-primary-rgb), .18);
}

.dropdown-item:active {
    background-color: var(--bs-primary);
}

/*** Spinner ***/
#spinner {
    opacity: 0;
    visibility: hidden;
    transition: opacity .5s ease-out, visibility 0s linear .5s;
    z-index: 99999;
}

#spinner.show {
    transition: opacity .5s ease-out, visibility 0s linear 0s;
    visibility: visible;
    opacity: 1;
}

.back-to-top {
    position: fixed;
    display: none;
    right: 45px;
    bottom: 45px;
    z-index: 99;
}

/*** Button ***/
.btn {
    transition: .5s;
    border-radius: 999px;
    font-family: "Space Grotesk", sans-serif;
    font-weight: 700;
    letter-spacing: .04em;
}

.btn-square {
    width: 38px;
    height: 38px;
}

.btn-sm-square {
    width: 32px;
    height: 32px;
}

.btn-lg-square {
    width: 48px;
    height: 48px;
}

.btn-square,
.btn-sm-square,
.btn-lg-square {
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: normal;
}


/*** Navbar ***/
.sticky-top {
    top: -150px;
    transition: .5s;
}

.navbar {
    margin-top: 0;
    padding: 18px 22px;
    font-family: "Space Grotesk", sans-serif;
    font-size: 18px;
    background: transparent;
    border-radius: 0;
    border: 0;
    backdrop-filter: none;
    box-shadow: none;
}

.navbar .navbar-nav .nav-link {
    margin-left: 30px;
    padding: 0;
    outline: none;
    color: var(--bs-dark);
}

.navbar .navbar-nav .nav-link:hover,
.navbar .navbar-nav .nav-link.active {
    color: var(--bs-primary)
}

.navbar .dropdown-toggle::after {
    border: none;
    content: "\f107";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    vertical-align: middle;
    margin-left: 8px;
}

.navbar .dropdown-menu .dropdown-item:hover,
.navbar .dropdown-menu .dropdown-item.active {
    color: var(--bs-white);
    background: var(--bs-primary);
}

.navbar-brand h1 {
    color: var(--bs-dark);
    letter-spacing: .06em;
}

.navbar-brand img {
    width: 56px;
    height: 56px;
    object-fit: cover;
    border-radius: 50%;
    border: 2px solid rgba(var(--bs-primary-rgb), .55);
}

.navbar-brand h1.mb-0 {
    font-size: 1.5rem;
    text-transform: uppercase;
}

.menu-toggle {
    display: inline-flex;
    align-items: center;
    gap: .9rem;
    padding: .85rem 0;
    border: 0;
    background: transparent;
    color: var(--bs-dark);
    font-family: "Space Grotesk", sans-serif;
    font-size: .98rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.menu-toggle-bars {
    display: inline-flex;
    flex-direction: column;
    gap: 5px;
}

.menu-toggle-bars span {
    display: block;
    width: 22px;
    height: 2px;
    background: var(--bs-dark);
    transition: transform .35s ease, opacity .35s ease;
}

.menu-overlay {
    position: fixed;
    inset: 0;
    z-index: 2000;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity .45s ease, visibility 0s linear .45s;
}

.menu-overlay.is-open {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transition: opacity .45s ease, visibility 0s linear 0s;
}

.menu-overlay-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(11, 11, 11, .24);
    backdrop-filter: blur(4px);
}

.menu-overlay-panel {
    position: relative;
    display: grid;
    grid-template-columns: minmax(320px, 42%) 1fr;
    height: 100%;
    background: transparent;
    transform: translateY(-18px);
    transition: transform .45s ease;
}

.menu-overlay.is-open .menu-overlay-panel {
    transform: translateY(0);
}

.menu-overlay-left {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    padding: 1.75rem 2rem 2rem;
    background: linear-gradient(180deg, rgba(11, 11, 11, .74), rgba(34, 24, 8, .72));
    border-right: 1px solid rgba(227, 154, 42, .22);
    backdrop-filter: blur(18px);
    box-shadow: 22px 0 48px rgba(0, 0, 0, .22);
}

.menu-overlay-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 4rem;
}

.menu-close {
    border: 0;
    background: transparent;
    color: rgba(255, 255, 255, .88);
    font-size: 2.2rem;
    line-height: 1;
}

.menu-overlay-body {
    display: flex;
    flex: 1;
    flex-direction: column;
    justify-content: center;
    align-items: flex-end;
}

.menu-kicker {
    margin-bottom: 2rem;
    color: var(--bs-white);
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(2.5rem, 5vw, 4.2rem);
    font-weight: 700;
    letter-spacing: .18em;
    text-transform: uppercase;
}

.menu-overlay-nav {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 1rem;
}

.menu-overlay-nav a {
    color: rgba(255, 248, 235, .78);
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(1.05rem, 2vw, 1.55rem);
    letter-spacing: .18em;
    text-transform: uppercase;
    transition: color .3s ease, transform .3s ease;
}

.menu-overlay-nav a:hover,
.menu-overlay-nav a.active {
    color: var(--bs-primary);
    transform: translateX(-8px);
}

.menu-socials {
    display: flex;
    gap: .8rem;
    margin-top: 2.5rem;
}

.menu-socials a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    border: 1px solid rgba(227, 154, 42, .18);
    color: rgba(255, 248, 235, .8);
    background: rgba(227, 154, 42, .08);
}

.menu-socials a:hover {
    color: var(--bs-dark);
    background: var(--bs-primary);
    border-color: var(--bs-primary);
}

.menu-overlay-right {
    position: relative;
    overflow: hidden;
    pointer-events: none;
}

.menu-overlay-right img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0;
    transform: scale(1.04);
}

.menu-overlay-image-layer {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(11, 11, 11, .2), rgba(11, 11, 11, 0)),
        linear-gradient(180deg, rgba(227, 154, 42, .04), rgba(11, 11, 11, .16));
}

.menu-overlay.is-open .menu-overlay-nav a,
.menu-overlay.is-open .menu-socials a,
.menu-overlay.is-open .menu-kicker {
    animation: menuFadeSlide .5s ease forwards;
}

@keyframes menuFadeSlide {
    from {
        opacity: 0;
        transform: translateX(18px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

body.menu-open {
    overflow: hidden;
}

@media (max-width: 991.98px) {
    .menu-overlay-panel {
        grid-template-columns: 1fr;
    }

    .menu-overlay-right {
        display: none;
    }

    .menu-overlay-left {
        padding: 1.4rem 1.25rem 2rem;
    }

    .menu-overlay-body {
        align-items: flex-start;
    }

    .menu-overlay-nav {
        align-items: flex-start;
    }

    .menu-overlay-nav a:hover,
    .menu-overlay-nav a.active {
        transform: none;
    }
}


/*** Hero Header ***/
.hero-header {
    margin-top: -100px;
    padding-top: 150px;
    background:
        linear-gradient(rgba(255, 253, 248, .82), rgba(248, 241, 228, .9)),
        url(../img/hero-bg.jpg) top center no-repeat;
    background-size: cover;
}

.hero-header .breadcrumb-item+.breadcrumb-item::before {
    color: var(--light);
}

.header-carousel {
    position: relative;
    padding: 45px 90px 45px 0;
}

.header-carousel::before {
    position: absolute;
    content: "";
    top: 0;
    right: 0;
    width: calc(50% + 45px);
    height: 100%;
    background: linear-gradient(180deg, var(--lux-gold), var(--bs-primary));
    z-index: -1;
}

.header-carousel .owl-dots {
    position: absolute;
    top: 50%;
    right: 38px;
    transform: translateY(-50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.header-carousel .owl-dot {
    position: relative;
    display: inline-block;
    margin: 5px 0;
    width: 15px;
    height: 15px;
    border: 2px solid var(--bs-white);
    transition: .5s;
}

.header-carousel .owl-dot.active {
    height: 30px;
    background: var(--bs-white);
}


/*** About ***/
.about-img {
    position: relative;
    overflow: hidden;
}

.about-img::after {
    position: absolute;
    content: "";
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background:
        radial-gradient(circle at top left, rgba(205, 164, 94, 0.2), transparent 55%),
        linear-gradient(135deg, rgba(205, 164, 94, 0.12), transparent 60%);
}

.about-story {
    position: relative;
}

.about-image-stack {
    display: flex;
    flex-direction: column;
}

.about-image-stack-photo {
    width: 100%;
    flex: 1 1 auto;
    object-fit: cover;
}

.about-image-caption {
    flex: 0 0 auto;
    justify-content: center;
}

.about-image-caption h4 {
    width: 100%;
    font-size: 1.1rem;
    line-height: 1.5;
    word-break: break-word;
}

.about-lead {
    font-weight: 700;
    line-height: 1.5;
    color: var(--bs-dark);
}

.about-story p {
    color: #5d6370;
    line-height: 1.9;
}

.about-story strong {
    color: var(--bs-dark);
    letter-spacing: .04em;
}

.about-highlight {
    display: inline-block;
    padding: 0 .35rem;
    margin: 0 .08rem;
    font-weight: 700;
    color: var(--bs-primary);
    background: linear-gradient(180deg, rgba(205, 164, 94, 0.12) 0%, rgba(205, 164, 94, 0.3) 100%);
    border-radius: 999px;
    box-shadow: inset 0 -1px 0 rgba(205, 164, 94, 0.18);
}


/*** Project ***/
.project-item img {
    transition: .5s;
}
  
.project-item:hover img {
    transform: scale(1.2);
}
  
.project-overlay {
    position: absolute;
    padding: 25px;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-end;
    background: linear-gradient(rgba(11, 11, 11, .05) 35%, rgba(11, 11, 11, .92));
    z-index: 1;
}


/*** Service ***/
.service-item {
    position: relative;
    padding: 30px 25px;
    transition: .5s;
}

.service-item.bg-primary:hover {
    background: var(--bs-light) !important;
}

.service-item.bg-primary p {
    color: var(--bs-light);
    transition: .5s;
}

.service-item.bg-primary:hover p {
    color: var(--bs-secondary);
}

.service-item.bg-light:hover {
    background: var(--bs-primary) !important;
}

.service-item.bg-light p {
    color: var(--bs-secondary);
    transition: .5s;
}

.service-item.bg-light:hover p {
    color: var(--bs-light);
}


.service-item .service-img h3 {
    position: absolute;
    top: 0;
    left: 0;
    padding: 0 12px 7px 0;
}

.service-item.bg-primary .service-img h3 {
    background: var(--bs-primary);
    color: var(--bs-white);
    transition: .5s;
}

.service-item.bg-primary:hover .service-img h3 {
    background: var(--bs-light);
    color: var(--bs-dark);
}

.service-item.bg-light .service-img h3 {
    background: var(--bs-light);
    color: var(--bs-dark);
    transition: .5s;
}

.service-item.bg-light:hover .service-img h3 {
    background: var(--bs-primary);
    color: var(--bs-white);
}


/*** Our Team ***/
.team-item img {
    transition: .5s;
}
  
.team-item:hover img {
    transform: scale(1.2);
}
  
.team-overlay {
    position: absolute;
    padding: 30px;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-end;
    background: linear-gradient(rgba(11, 11, 11, .05) 35%, rgba(11, 11, 11, .92));
    z-index: 1;
}

.team-overlay small {
    display: inline-block;
    padding: 3px 15px;
    color: var(--bs-white);
    background: var(--bs-primary);
}


/*** Testimonial ***/
.testimonial-img {
    position: relative;
    padding: 45px 0 45px 90px;
}

.testimonial-img::before {
    position: absolute;
    content: "";
    top: 0;
    left: 0;
    width: calc(50% + 45px);
    height: 100%;
    background: var(--bs-primary);
    z-index: -1;
}

.testimonial-text h5 {
    position: relative;
    padding-left: 45px;
}

.testimonial-text h5::before {
    position: absolute;
    content: "";
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    width: 40px;
    height: 2px;
    background: var(--bs-primary);
}

.testimonial-carousel .owl-dots {
    position: absolute;
    height: 17px;
    bottom: 0;
    right: 0;
    left: auto;
}

.testimonial-carousel .owl-dot {
    position: relative;
    display: inline-block;
    margin-left: 10px;
    width: 15px;
    height: 15px;
    background: var(--bs-white);
    border: 2px solid var(--bs-primary);
    transition: .5s;
}

.testimonial-carousel .owl-dot.active {
    width: 30px;
    background: var(--bs-primary);
}

@media (max-width: 768px) {
    .testimonial-carousel .owl-dots {
        left: 0;
        right: auto;
    }

    .testimonial-carousel .owl-dot {
        margin-right: 10px;
        margin-left: 0;
    }
}


/*** Newsletter ***/
.newsletter {
    background:
        linear-gradient(rgba(11, 11, 11, .78), rgba(11, 11, 11, .78)),
        url(../img/hero-bg.jpg) bottom right no-repeat;
    background-size: cover;
}

@media (min-width: 992px) {
    .newsletter .container {
        max-width: 100% !important;
    }

    .newsletter .newsletter-text  {
        padding-right: calc(((100% - 960px) / 2) + .75rem);
    }
}

@media (min-width: 1200px) {
    .newsletter .newsletter-text  {
        padding-right: calc(((100% - 1140px) / 2) + .75rem);
    }
}

@media (min-width: 1400px) {
    .newsletter .newsletter-text  {
        padding-right: calc(((100% - 1320px) / 2) + .75rem);
    }
}


/*** Footer ***/
.footer .btn.btn-link {
    display: block;
    margin-bottom: 10px;
    padding: 0;
    text-align: left;
    color: rgba(255,255,255,.5);
    font-weight: normal;
    transition: .3s;
}

.footer .btn.btn-link:hover {
    color: var(--bs-white);
    letter-spacing: 1px;
    box-shadow: none;
}

.footer .btn.btn-link::before {
    position: relative;
    content: "\f105";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    margin-right: 10px;
}

.footer .copyright {
    padding: 25px 0;
    font-size: 14px;
    border-top: 1px solid rgba(256, 256, 256, .1);
}

.footer .copyright a {
    color: rgba(255,255,255,.5);
}

.footer .copyright a:hover {
    color: var(--bs-white);
}

.footer .footer-menu a {
    margin-right: 15px;
    padding-right: 15px;
    border-right: 1px solid rgba(255, 255, 255, .1);
}

.footer .footer-menu a:last-child {
    margin-right: 0;
    padding-right: 0;
    border-right: none;
}

.py-6 {
    padding-top: 6rem;
    padding-bottom: 6rem;
}

.ar-hero {
    position: relative;
    overflow: hidden;
    min-height: 100vh;
    display: flex;
    align-items: center;
    padding-left: 0;
    padding-right: 0;
}

.ar-hero::before {
    position: absolute;
    content: "";
    inset: 0;
    background:
        radial-gradient(circle at top left, rgba(227, 154, 42, .18), transparent 28%),
        linear-gradient(120deg, rgba(7, 7, 7, .40), rgba(7, 7, 7, .18));
    z-index: 1;
}

.ar-hero::after {
    position: absolute;
    content: "";
    inset: 0;
    background:
        linear-gradient(90deg, rgba(255, 255, 255, .16) 1px, transparent 1px),
        linear-gradient(rgba(255, 255, 255, .12) 1px, transparent 1px);
    background-size: 120px 120px;
    opacity: .22;
    mask-image: linear-gradient(180deg, rgba(0, 0, 0, .35), transparent 75%);
    z-index: 1;
}

.hero-background-media {
    position: absolute;
    inset: 0;
    z-index: 0;
    animation: heroMediaFloat 18s ease-in-out infinite alternate;
}

.hero-background-carousel,
.hero-background-carousel .owl-stage-outer,
.hero-background-carousel .owl-stage,
.hero-background-carousel .owl-item {
    height: 100%;
}

.hero-background-carousel .owl-item img {
    width: 100%;
    height: 100%;
    min-height: 100vh;
    object-fit: cover;
    transform: scale(1.06);
}

.hero-video-slide,
.hero-background-carousel .owl-item .hero-video-slide {
    position: relative;
    width: 100%;
    height: 100%;
}

.hero-background-video {
    width: 100%;
    height: 100%;
    min-height: 100vh;
    object-fit: cover;
    transform: scale(1.06);
}

.hero-video-fallback {
    position: absolute;
    left: 50%;
    bottom: 96px;
    transform: translateX(-50%);
    z-index: 4;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 190px;
    padding: 0.95rem 1.4rem;
    border: 1px solid rgba(255, 255, 255, 0.34);
    border-radius: 999px;
    background: rgba(12, 11, 10, 0.72);
    color: #fff;
    font-weight: 600;
    letter-spacing: 0.02em;
    backdrop-filter: blur(10px);
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.28);
}

.hero-video-fallback[hidden] {
    display: none;
}

.hero-video-fallback:hover {
    background: rgba(12, 11, 10, 0.84);
    color: #fff;
}

.hero-background-carousel.header-carousel {
    padding: 0;
}

.hero-background-carousel.header-carousel::before {
    display: none;
}

.hero-background-carousel .owl-dots {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 28px;
    display: flex;
    justify-content: center;
    gap: 10px;
    padding: 0 18px;
    z-index: 3;
}

.hero-background-carousel .owl-dots .owl-dot span {
    width: 12px;
    height: 12px;
    background: rgba(255, 255, 255, .55);
    border: 1px solid rgba(255, 255, 255, .4);
    transition: transform .25s ease, background .25s ease;
}

.hero-background-carousel .owl-dots .owl-dot.active span,
.hero-background-carousel .owl-dots .owl-dot:hover span {
    background: var(--bs-primary);
    border-color: var(--bs-primary);
    transform: scale(1.1);
}

.hero-background-overlay {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(11, 11, 11, .84) 0%, rgba(11, 11, 11, .56) 40%, rgba(11, 11, 11, .2) 100%),
        linear-gradient(180deg, rgba(11, 11, 11, .22), rgba(11, 11, 11, .42));
    z-index: 1;
    pointer-events: none;
}

.ar-hero .container {
    position: relative;
    z-index: 2;
}

.home-hero-nav .navbar-brand h1,
.home-hero-nav .menu-toggle,
.home-hero-nav .menu-toggle-bars span {
    color: var(--bs-white);
}

.home-hero-nav .menu-toggle-bars span {
    background: var(--bs-white);
}

.hero-title {
    max-width: 11ch;
    color: var(--bs-white);
    font-size: clamp(3.4rem, 8vw, 6.2rem);
    line-height: .94;
    letter-spacing: -.04em;
    text-shadow: 0 10px 36px rgba(0, 0, 0, .35);
}

.hero-subtitle {
    max-width: 740px;
    color: rgba(255, 248, 235, .86);
    font-size: clamp(1.08rem, 2vw, 1.4rem);
    line-height: 1.7;
}

.hero-pills {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, max-content));
    gap: .9rem 1.6rem;
    align-items: start;
    max-width: 34rem;
}

.hero-pills span {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: .7rem;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: none;
    color: rgba(255, 248, 235, .92);
    font-family: "Space Grotesk", sans-serif;
    font-size: .92rem;
    font-weight: 500;
    letter-spacing: .04em;
}

.hero-pills span::before {
    content: "";
    width: .55rem;
    height: .55rem;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--bs-primary), #f2d082);
    box-shadow: 0 0 0 6px rgba(var(--bs-primary-rgb), .12);
    flex: 0 0 auto;
}

.hero-actions .btn-outline-primary {
    color: var(--bs-white);
    border-color: rgba(227, 154, 42, .75);
    background: rgba(255, 253, 248, .04);
}

.hero-actions .btn-outline-primary:hover {
    color: var(--bs-dark);
    background: var(--bs-primary);
    border-color: var(--bs-primary);
}

.hero-eyebrow,
.section-tag {
    display: none !important;
    margin-bottom: 1rem;
    padding: .55rem 1rem;
    border: 1px solid rgba(var(--bs-primary-rgb), .35);
    background: rgba(255, 255, 255, .78);
    color: var(--lux-gold-deep);
    font-size: .85rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    border-radius: 999px;
    box-shadow: 0 10px 22px rgba(11, 11, 11, .05);
}

.section-tag-dark {
    display: none !important;
    background: rgba(255, 255, 255, .08);
    color: var(--bs-primary);
    border-color: rgba(var(--bs-primary-rgb), .3);
}

.hero-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.hero-metric {
    position: relative;
    padding: 1.25rem;
    background: rgba(255, 253, 248, .14);
    border: 1px solid rgba(var(--bs-primary-rgb), .18);
    box-shadow: 0 12px 28px rgba(11, 11, 11, .14);
    backdrop-filter: blur(12px);
    border-radius: 24px;
    overflow: hidden;
}

.hero-metric::before {
    position: absolute;
    content: "";
    top: 0;
    left: 0;
    width: 100%;
    height: 4px;
    background: linear-gradient(90deg, var(--bs-primary), rgba(207, 166, 74, .35));
}

.hero-metric strong {
    display: block;
    margin-bottom: .35rem;
    color: var(--bs-white);
    font-family: "Space Grotesk", sans-serif;
    font-size: 1.35rem;
}

.hero-metric span {
    color: rgba(255, 248, 235, .82);
    font-size: .92rem;
}

.hero-floating-card {
    position: relative;
    max-width: 320px;
    margin-top: 4rem;
    padding: 1.4rem;
    background: rgba(255, 253, 248, .9);
    border-left: 4px solid var(--bs-primary);
    box-shadow: 0 16px 36px rgba(11, 11, 11, .18);
    transition: transform .6s ease, box-shadow .4s ease;
    border-radius: 22px;
    backdrop-filter: blur(14px);
}

.hero-floating-card-inner {
    animation: floatingCardDrift 6s ease-in-out infinite;
}

.hero-floating-card p {
    color: #5d5140;
    line-height: 1.7;
}

.hero-scroll-cue {
    position: absolute;
    left: 50%;
    bottom: 26px;
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: .35rem;
    transform: translateX(-50%);
    color: rgba(255, 248, 235, .8);
    font-family: "Space Grotesk", sans-serif;
    font-size: .84rem;
    letter-spacing: .18em;
    text-transform: uppercase;
}

.hero-scroll-cue i {
    font-size: 1.35rem;
    color: var(--bs-primary);
    animation: heroScrollBounce 1.8s ease-in-out infinite;
}

.ar-promo-strip {
    background: linear-gradient(90deg, var(--bs-dark), #1d1509);
    border-top: 1px solid rgba(227, 154, 42, .18);
    border-bottom: 1px solid rgba(227, 154, 42, .18);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .04);
}

.section-heading {
    max-width: 720px;
    margin-bottom: 3rem;
}

.section-heading h1 {
    font-size: clamp(2.2rem, 4vw, 3.6rem);
    line-height: 1.05;
    margin-bottom: 1rem;
}

.section-heading.text-center {
    margin-left: auto;
    margin-right: auto;
}

.section-heading p {
    color: #6f6558;
    margin-bottom: 0;
}

.property-card,
.trust-card,
.service-panel,
.cta-panel {
    border: 1px solid rgba(var(--bs-primary-rgb), .16);
    box-shadow: 0 16px 40px rgba(11, 11, 11, .08);
    border-radius: 28px;
}

.property-card {
    position: relative;
    height: 100%;
    overflow: hidden;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, .96), rgba(250, 244, 234, .96));
    transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease;
}

.property-card img {
    height: 280px;
    object-fit: cover;
    transition: transform .65s ease;
}

.property-card-featured img {
    height: 380px;
}

.property-card-body {
    position: relative;
    padding: 1.75rem;
}

.property-card-body::before {
    position: absolute;
    content: "";
    top: 0;
    left: 1.75rem;
    width: 64px;
    height: 2px;
    background: linear-gradient(90deg, var(--bs-primary), transparent);
}

.badge-label {
    display: inline-block;
    margin-bottom: .75rem;
    color: var(--lux-gold-deep);
    font-size: .82rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
}

.status-label {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    padding: .48rem .95rem;
    border: 1px solid transparent;
    border-radius: 999px;
    font-size: .75rem;
    line-height: 1;
    letter-spacing: .12em;
}

.status-label::before {
    content: "";
    width: .55rem;
    height: .55rem;
    border-radius: 50%;
    background: currentColor;
    box-shadow: 0 0 0 4px rgba(255, 255, 255, .08);
}

.status-in-progress {
    color: #f4c152;
    background: rgba(244, 193, 82, .12);
    border-color: rgba(244, 193, 82, .28);
}

.status-finished {
    color: #7fd39a;
    background: rgba(127, 211, 154, .14);
    border-color: rgba(127, 211, 154, .3);
}

.status-study {
    color: #8ec5ff;
    background: rgba(142, 197, 255, .14);
    border-color: rgba(142, 197, 255, .32);
}

.status-section-title {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: .8rem;
    padding: .7rem 1.2rem;
    border-radius: 999px;
    background: linear-gradient(135deg, rgba(16, 14, 10, .96), rgba(48, 34, 19, .92));
    color: var(--bs-white);
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(1.2rem, 2vw, 1.55rem);
    font-weight: 700;
    letter-spacing: .03em;
    box-shadow: 0 16px 38px rgba(10, 8, 5, .14);
}

.status-section-title::before {
    content: "";
    width: .8rem;
    height: .8rem;
    border-radius: 50%;
    background: linear-gradient(135deg, #efc670, #c79032);
    box-shadow: 0 0 0 6px rgba(212, 162, 74, .14);
}

.status-section-note {
    max-width: 42rem;
    padding-left: .4rem;
    color: rgba(52, 41, 25, .74);
    font-size: .98rem;
    line-height: 1.7;
}

.status-section-note + .row,
.status-section-note + .project-group {
    position: relative;
}

.status-section-note + .row::before,
.status-section-note + .project-group::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: -1.2rem;
    height: 1px;
    background: linear-gradient(90deg, rgba(199, 144, 50, .42), rgba(199, 144, 50, .12), transparent);
}

.lifestyle-grid {
    display: grid;
    grid-template-columns: 1.2fr .8fr;
    gap: 1rem;
}

.lifestyle-grid img {
    width: 100%;
    object-fit: cover;
    box-shadow: 0 18px 42px rgba(11, 11, 11, .10);
    transition: transform .45s ease, box-shadow .45s ease;
    border-radius: 28px;
}

.lifestyle-lg {
    grid-row: span 2;
    height: 520px;
}

.lifestyle-sm {
    height: 250px;
}

.lifestyle-wide {
    height: 250px;
}

.check-grid {
    display: grid;
    gap: .9rem;
    color: #574f44;
    font-weight: 600;
}

.trust-card {
    height: 100%;
    padding: 2rem 1.5rem;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, .98), rgba(249, 243, 233, .92));
    transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}

.trust-card i {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 68px;
    height: 68px;
    margin-bottom: 1.25rem;
    background: rgba(var(--bs-primary-rgb), .12);
    font-size: 1.4rem;
    border-radius: 20px;
}

.service-panel {
    overflow: hidden;
    height: 100%;
    background:
        linear-gradient(180deg, rgba(255, 253, 248, .98), rgba(246, 238, 223, .96));
    transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease;
}

.service-panel img {
    width: 100%;
    height: 220px;
    object-fit: cover;
    transition: transform .65s ease;
}

.service-panel-body {
    padding: 1.5rem;
}

.cta-panel {
    padding: 3rem;
    background:
        linear-gradient(135deg, rgba(255, 249, 239, .94), rgba(248, 241, 228, .94)),
        var(--bs-light);
    position: relative;
    overflow: hidden;
}

.cta-panel::before {
    position: absolute;
    content: "";
    inset: auto -60px -60px auto;
    width: 220px;
    height: 220px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(227, 154, 42, .22), transparent 70%);
}

.cta-panel::after {
    position: absolute;
    content: "";
    inset: 0;
    border: 1px solid rgba(227, 154, 42, .12);
    border-radius: 28px;
    pointer-events: none;
}

.property-card:hover,
.trust-card:hover,
.service-panel:hover {
    transform: translateY(-8px);
    border-color: rgba(var(--bs-primary-rgb), .4);
    box-shadow: 0 24px 48px rgba(11, 11, 11, .14);
}

.property-card:hover img,
.service-panel:hover img,
.lifestyle-grid img:hover {
    transform: scale(1.04);
}

.hero-floating-card:hover {
    box-shadow: 0 20px 42px rgba(11, 11, 11, .2);
}

.menu-overlay-left,
.menu-socials a,
.hero-metric,
.property-card,
.trust-card,
.service-panel,
.cta-panel {
    box-shadow:
        0 18px 44px rgba(11, 11, 11, .10),
        inset 0 1px 0 rgba(255, 255, 255, .32);
}

.simple-project-block {
    height: 100%;
    overflow: hidden;
    border-radius: 24px;
    background: linear-gradient(180deg, rgba(255, 255, 255, .98), rgba(248, 241, 228, .92));
    border: 1px solid rgba(var(--bs-primary-rgb), .14);
    box-shadow: 0 16px 38px rgba(11, 11, 11, .08);
    transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}

.simple-project-block img {
    height: 260px;
    object-fit: cover;
    transition: transform .5s ease;
}

.simple-project-content {
    padding: 1.5rem;
}

.simple-project-content h4 {
    margin-bottom: .75rem;
}

.simple-project-block:hover {
    transform: translateY(-6px);
    border-color: rgba(var(--bs-primary-rgb), .35);
    box-shadow: 0 22px 44px rgba(11, 11, 11, .12);
}

.simple-project-block:hover img {
    transform: scale(1.04);
}

.project-group {
    display: grid;
    gap: 1.5rem;
}

.project-group-copy {
    max-width: 760px;
}

.project-group-tag {
    display: inline-block;
    margin-bottom: .85rem;
    color: var(--lux-gold-deep);
    font-size: .82rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
}

.project-group-copy h3 {
    margin-bottom: .85rem;
    font-size: clamp(1.8rem, 4vw, 2.8rem);
}

.project-group-copy p {
    margin-bottom: 1.25rem;
    max-width: 680px;
    color: #655c51;
    font-size: 1.05rem;
    line-height: 1.8;
}

.projects-animation-wrap {
    overflow: visible;
}

.medium.row {
    position: relative;
    min-height: 360px;
    margin: 0;
    align-items: center;
    display: flex;
    overflow: visible;
}

.square {
    width: 240px;
    border-radius: 24px;
    overflow: hidden;
    border: 1px solid rgba(var(--bs-primary-rgb), .14);
    background: linear-gradient(180deg, rgba(255, 255, 255, .98), rgba(248, 241, 228, .92));
    box-shadow: 0 16px 38px rgba(11, 11, 11, .08);
    will-change: transform;
}

#project-trigger {
    position: relative;
    z-index: 5;
    width: 300px;
    cursor: pointer;
}

#project-trigger-second {
    position: relative;
    z-index: 5;
    width: 300px;
    cursor: pointer;
}

#project-trigger-third {
    position: relative;
    z-index: 5;
    width: 300px;
    cursor: pointer;
}

#project-trigger::after,
#project-trigger-second::after,
#project-trigger-third::after {
    position: absolute;
    content: "Survolez pour decouvrir";
    left: 18px;
    bottom: 18px;
    padding: .55rem .85rem;
    border-radius: 999px;
    background: rgba(11, 11, 11, .68);
    color: rgba(255, 248, 235, .92);
    font-family: "Space Grotesk", sans-serif;
    font-size: .8rem;
    letter-spacing: .06em;
    text-transform: uppercase;
    z-index: 2;
}

.reveal-square {
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translate3d(0, 0, 0) scale(1) rotate(0turn);
    transition:
        transform .9s cubic-bezier(.19, 1, .22, 1),
        opacity .45s ease,
        visibility 0s linear .45s;
}

.reveal-square.is-visible {
    visibility: visible;
    transition:
        transform .9s cubic-bezier(.19, 1, .22, 1),
        opacity .45s ease,
        visibility 0s linear 0s;
}

#css-selector-id {
    z-index: 4;
    --project-offset: 16rem;
}

#project-third {
    z-index: 3;
    --project-offset: 30rem;
}

#project-fourth {
    z-index: 2;
    --project-offset: 44rem;
}

#project-fifth {
    z-index: 1;
    --project-offset: 58rem;
}

#project-seven {
    z-index: 4;
}

#project-eight {
    z-index: 3;
}

#project-nine {
    z-index: 2;
}

#project-eleven {
    z-index: 4;
}

#project-twelve {
    z-index: 3;
}

#project-thirteen {
    z-index: 2;
}

#projects-animation-wrap.projects-open #css-selector-id {
    opacity: 1;
    transform: translate3d(16rem, 0, 0) rotate(1turn);
}

#projects-animation-wrap.projects-open #project-third {
    opacity: 1;
    transform: translate3d(30rem, 0, 0) scale(.5);
}

#projects-animation-wrap.projects-open #project-fourth {
    opacity: 1;
    transform: translate3d(44rem, 0, 0) scale(1);
    transition-delay: .18s;
}

#projects-animation-wrap.projects-open #project-fifth {
    opacity: 1;
    transform: translate3d(58rem, 0, 0) translateY(1rem);
    transition-delay: .26s;
}

#projects-animation-wrap-second.projects-open #project-seven {
    opacity: 1;
    transform: translate3d(16rem, 0, 0) rotate(1turn);
}

#projects-animation-wrap-second.projects-open #project-eight {
    opacity: 1;
    transform: translate3d(30rem, 0, 0) scale(.5);
}

#projects-animation-wrap-second.projects-open #project-nine {
    opacity: 1;
    transform: translate3d(44rem, 0, 0) scale(1);
    transition-delay: .18s;
}

#projects-animation-wrap-third.projects-open #project-eleven {
    opacity: 1;
    transform: translate3d(16rem, 0, 0) rotate(1turn);
}

#projects-animation-wrap-third.projects-open #project-twelve {
    opacity: 1;
    transform: translate3d(30rem, 0, 0) scale(.5);
}

#projects-animation-wrap-third.projects-open #project-thirteen {
    opacity: 1;
    transform: translate3d(44rem, 0, 0) scale(1);
    transition-delay: .18s;
}

.square img {
    display: block;
    height: 340px;
    object-fit: cover;
}

.project-detail-page {
    min-height: 100vh;
    padding: 3rem 0 5rem;
    background:
        radial-gradient(circle at top left, rgba(18, 89, 68, .28), transparent 22%),
        radial-gradient(circle at bottom right, rgba(227, 154, 42, .08), transparent 18%),
        linear-gradient(180deg, #07231e 0%, #031412 100%);
    color: rgba(240, 241, 236, .94);
}

.project-detail-shell {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(320px, .95fr);
    gap: 4rem;
    align-items: center;
}

.project-detail-intro {
    color: rgba(255, 255, 255, .7);
    font-size: 1.05rem;
    letter-spacing: .04em;
}

.project-detail-name {
    margin: .35rem 0 1.6rem;
    color: #f4c56b;
    font-family: "Brush Script MT", "Segoe Script", cursive;
    font-size: clamp(3.8rem, 8vw, 6.8rem);
    line-height: .92;
    font-weight: 400;
}

.project-detail-copy {
    max-width: 680px;
    margin-bottom: 2rem;
    color: rgba(238, 240, 235, .82);
    font-size: 1.08rem;
    line-height: 1.75;
}

.project-detail-status {
    margin-bottom: 1.5rem;
    color: #f4c56b;
    font-family: "Space Grotesk", sans-serif;
    font-size: 1.15rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.project-detail-facts {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    max-width: 720px;
}

.project-detail-fact {
    padding: 1.35rem 1.45rem;
    border: 1px solid rgba(255, 255, 255, .08);
    border-radius: 18px;
    background: rgba(120, 160, 148, .18);
    box-shadow: 0 18px 40px rgba(0, 0, 0, .18);
}

.project-detail-fact span {
    display: block;
    margin-bottom: .55rem;
    color: rgba(220, 228, 223, .7);
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.project-detail-fact strong {
    color: #ffffff;
    font-family: "Space Grotesk", sans-serif;
    font-size: 1.8rem;
    line-height: 1.1;
}

.project-detail-media {
    position: relative;
    padding: 1rem;
    border-radius: 34px;
    background: rgba(255, 255, 255, .05);
    box-shadow: 0 28px 60px rgba(0, 0, 0, .28);
}

.project-detail-media img {
    width: 100%;
    border-radius: 28px;
    display: block;
}

.project-detail-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    margin-top: 2rem;
}

.project-page-hero {
    position: relative;
    overflow: hidden;
    min-height: 88vh;
    display: flex;
    align-items: flex-end;
    background: linear-gradient(180deg, #120f0b 0%, #0b0b0b 100%);
}

.project-page-hero-media,
.project-page-hero-overlay {
    position: absolute;
    inset: 0;
}

.project-page-hero-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transform: scale(1.06);
    filter: saturate(.94);
}

.project-page-hero-overlay {
    background:
        linear-gradient(90deg, rgba(11, 11, 11, .88) 0%, rgba(11, 11, 11, .55) 48%, rgba(11, 11, 11, .72) 100%),
        radial-gradient(circle at 80% 20%, rgba(227, 154, 42, .22), transparent 26%);
}

.project-page-hero .container {
    z-index: 1;
}

.project-page-hero-copy {
    max-width: 760px;
}

.project-page-summary {
    display: grid;
    gap: 1rem;
}

.project-page-summary-stat,
.project-spotlight-card {
    padding: 1.5rem;
    border-radius: 26px;
    border: 1px solid rgba(var(--bs-primary-rgb), .18);
    box-shadow: 0 18px 44px rgba(11, 11, 11, .10);
    background: linear-gradient(180deg, rgba(255, 253, 248, .96), rgba(246, 239, 226, .96));
}

.project-page-summary-stat {
    background: rgba(255, 253, 248, .12);
    backdrop-filter: blur(14px);
    color: var(--bs-white);
}

.project-page-summary-stat strong {
    display: block;
    margin-bottom: .3rem;
    font-size: 1.3rem;
    font-family: "Space Grotesk", sans-serif;
}

.project-page-summary-stat span {
    color: rgba(255, 248, 235, .82);
}

.project-spotlight-card {
    position: relative;
    overflow: hidden;
}

.project-spotlight-card::after {
    position: absolute;
    content: "";
    inset: auto -50px -50px auto;
    width: 180px;
    height: 180px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(227, 154, 42, .18), transparent 70%);
}

.project-fact-list {
    display: grid;
    gap: .95rem;
}

.project-fact-list div {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    padding-bottom: .95rem;
    border-bottom: 1px solid rgba(var(--bs-primary-rgb), .12);
}

.project-fact-list div:last-child {
    padding-bottom: 0;
    border-bottom: 0;
}

.project-fact-list strong {
    color: var(--bs-dark);
    font-family: "Space Grotesk", sans-serif;
}

.project-fact-list span {
    color: #6a6154;
    text-align: right;
}

.project-spotlight-visual {
    position: relative;
    min-height: 620px;
    overflow: hidden;
    border-radius: 34px;
    box-shadow: 0 26px 54px rgba(11, 11, 11, .16);
}

.project-spotlight-visual img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.project-spotlight-visual::after {
    position: absolute;
    content: "";
    inset: 0;
    background: linear-gradient(180deg, rgba(11, 11, 11, .06), rgba(11, 11, 11, .42));
}

.project-spotlight-badge {
    position: absolute;
    right: 24px;
    bottom: 24px;
    z-index: 1;
    padding: 1rem 1.15rem;
    min-width: 220px;
    border-radius: 22px;
    background: rgba(255, 253, 248, .92);
    box-shadow: 0 18px 38px rgba(11, 11, 11, .16);
}

.project-spotlight-badge span {
    display: block;
    margin-bottom: .2rem;
    color: var(--lux-gold-deep);
    text-transform: uppercase;
    letter-spacing: .12em;
    font-size: .8rem;
    font-weight: 700;
}

.project-spotlight-badge strong {
    color: var(--bs-dark);
    font-family: "Space Grotesk", sans-serif;
    font-size: 1.1rem;
}

.project-showcase-card {
    height: 100%;
}

.project-showcase-card.project-showcase-card-lg img {
    height: 360px;
}

.project-card-head,
.project-card-meta {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
}

.project-card-head {
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1rem;
}

.project-status {
    display: inline-flex;
    align-items: center;
    padding: .45rem .9rem;
    border-radius: 999px;
    background: rgba(var(--bs-primary-rgb), .12);
    color: var(--lux-gold-deep);
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.project-status-soft {
    background: rgba(11, 11, 11, .06);
    color: #62584a;
}

.project-card-meta {
    margin-top: 1.2rem;
}

.project-card-meta span {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    padding: .55rem .9rem;
    border-radius: 999px;
    background: rgba(11, 11, 11, .04);
    color: #5d5448;
    font-size: .88rem;
}

.project-showcase-card-accent {
    background:
        linear-gradient(135deg, rgba(11, 11, 11, .96), rgba(39, 28, 13, .96)),
        var(--bs-dark);
    color: rgba(255, 248, 235, .88);
}

.project-showcase-card-accent .property-card-body::before {
    background: linear-gradient(90deg, var(--bs-primary), rgba(255, 255, 255, .14));
}

.project-showcase-card-accent h3,
.project-showcase-card-accent .badge-label {
    color: var(--bs-white);
}

.project-note-list {
    margin: 0;
    padding-left: 1.2rem;
    color: rgba(255, 248, 235, .84);
}

.project-note-list li + li {
    margin-top: .55rem;
}

.project-experience-card {
    min-height: 100%;
}

.project-cta-panel {
    margin-top: 1rem;
}

@keyframes heroMediaFloat {
    from {
        transform: translate3d(0, 0, 0) scale(1);
    }
    to {
        transform: translate3d(0, -10px, 0) scale(1.015);
    }
}

@keyframes floatingCardDrift {
    0%, 100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-8px);
    }
}

@keyframes heroScrollBounce {
    0%, 100% {
        transform: translateY(0);
        opacity: .9;
    }
    50% {
        transform: translateY(7px);
        opacity: 1;
    }
}

@media (max-width: 991.98px) {
    .hero-metrics {
        grid-template-columns: 1fr;
    }

    .hero-floating-card {
        max-width: none;
        margin-top: 1rem;
    }

    .lifestyle-grid {
        grid-template-columns: 1fr;
    }

    .lifestyle-lg,
    .lifestyle-sm,
    .lifestyle-wide {
        height: 260px;
    }

    .hero-title {
        max-width: none;
    }

    .hero-scroll-cue {
        display: none;
    }

    .project-page-hero {
        min-height: auto;
        padding-top: 8rem;
    }

    .project-spotlight-visual {
        min-height: 460px;
    }
}

@media (max-width: 575.98px) {
    .py-6 {
        padding-top: 4rem;
        padding-bottom: 4rem;
    }

    .ar-hero {
        min-height: auto;
    }

    .cta-panel {
        padding: 2rem 1.25rem;
    }

    .project-page-summary-stat,
    .project-spotlight-card {
        padding: 1.25rem;
    }

    .project-fact-list div {
        flex-direction: column;
    }

    .project-fact-list span {
        text-align: left;
    }

    .project-spotlight-visual {
        min-height: 340px;
        border-radius: 26px;
    }

    .project-spotlight-badge {
        right: 16px;
        bottom: 16px;
        min-width: 0;
        max-width: calc(100% - 32px);
    }

    .project-card-head {
        align-items: flex-start;
    }

    .medium.row {
        min-height: 260px;
    }

    .square {
        width: 190px;
    }

    .square img {
        height: 250px;
    }

    #project-trigger {
        width: 230px;
    }

    #project-trigger-second {
        width: 230px;
    }

    #project-trigger-third {
        width: 230px;
    }

    #css-selector-id {
        --project-offset: 10rem;
    }

    #project-third {
        --project-offset: 18rem;
    }

    #project-fourth {
        --project-offset: 26rem;
    }

    #project-fifth {
        --project-offset: 34rem;
    }
}

@media (max-width: 767.98px) {
    .hero-header.ar-hero {
        margin-top: -120px;
        padding-top: 170px;
    }

    .ar-hero {
        min-height: 82vh;
    }

    .hero-background-carousel .owl-item img {
        min-height: 65vh;
    }

    .hero-background-carousel .owl-dots {
        bottom: 16px;
        padding: 0 12px;
        gap: 8px;
        z-index: 4;
    }

    .project-group-copy p {
        font-size: 1rem;
    }

    .projects-animation-wrap {
        overflow: hidden;
    }

    .medium.row {
        min-height: auto;
        flex-direction: column;
        align-items: center;
        gap: 1.25rem;
    }

    .square,
    #project-trigger {
        position: relative;
        width: min(100%, 320px);
    }

    #project-trigger,
    #project-trigger-second,
    #project-trigger-third {
        width: min(100%, 320px);
    }

    #project-trigger::after,
    #project-trigger-second::after,
    #project-trigger-third::after {
        content: "Touchez pour ouvrir";
    }

    #project-trigger[aria-expanded="true"]::after,
    #project-trigger-second[aria-expanded="true"]::after,
    #project-trigger-third[aria-expanded="true"]::after {
        content: "Touchez pour fermer";
    }

    .square img {
        height: 260px;
    }

    .reveal-square {
        position: relative;
        top: auto;
        left: auto;
        display: block;
        max-height: 0;
        overflow: hidden;
        margin-top: 0;
        opacity: 0;
        visibility: hidden;
        pointer-events: auto;
        transform: translateY(-14px) scale(.98) !important;
        transition:
            max-height .45s ease,
            margin-top .45s ease,
            opacity .35s ease,
            transform .45s ease,
            visibility 0s linear .45s;
    }

    .projects-animation-wrap.projects-open .reveal-square {
        max-height: 280px;
        margin-top: .25rem;
        opacity: 1;
        visibility: visible;
        transform: translateY(0) scale(1) !important;
        transition:
            max-height .45s ease,
            margin-top .45s ease,
            opacity .35s ease,
            transform .45s ease,
            visibility 0s linear 0s;
    }

    .projects-animation-wrap .reveal-square.is-visible {
        visibility: visible;
    }

    .project-detail-shell {
        grid-template-columns: 1fr;
        gap: 2rem;
    }

    .project-detail-facts {
        grid-template-columns: 1fr;
    }

    .project-detail-name {
        font-size: clamp(3rem, 14vw, 4.6rem);
    }
}


/*** Brand Refresh ***/
:root {
    --bs-primary: #d4a24a;
    --bs-primary-rgb: 212, 162, 74;
    --bs-secondary: #8b95ab;
    --bs-secondary-rgb: 139, 149, 171;
    --bs-light: #f6f1e8;
    --bs-light-rgb: 246, 241, 232;
    --bs-dark: #090807;
    --bs-dark-rgb: 9, 8, 7;
    --bs-white: #fffaf2;
    --bs-white-rgb: 255, 250, 242;
    --lux-gold: #d4a24a;
    --lux-gold-deep: #96671d;
    --lux-black: #090807;
    --lux-ink: #18130c;
    --lux-slate: #8b95ab;
    --lux-slate-deep: #697184;
    --lux-stone: #d8cebf;
    --lux-panel: rgba(255, 250, 242, .84);
    --lux-panel-strong: rgba(255, 250, 242, .94);
    --lux-shadow: 0 22px 48px rgba(10, 8, 5, .12);
}

html {
    scroll-behavior: smooth;
    overflow-x: hidden;
}

body {
    position: relative;
    color: #574c40;
    font-family: "Open Sans", sans-serif;
    line-height: 1.75;
    overflow-x: hidden;
    background-color: #f7f2ea;
    background-image:
        radial-gradient(circle at top left, rgba(212, 162, 74, .14), transparent 23%),
        radial-gradient(circle at top right, rgba(139, 149, 171, .20), transparent 25%),
        radial-gradient(circle at bottom left, rgba(13, 11, 8, .05), transparent 30%),
        linear-gradient(180deg, #faf6ef 0%, #f1eadf 52%, #f7f2ea 100%);
}

body::before,
body::after {
    position: fixed;
    content: "";
    width: 26rem;
    height: 26rem;
    border-radius: 50%;
    filter: blur(18px);
    opacity: .55;
    pointer-events: none;
    z-index: -1;
}

body::before {
    top: -8rem;
    right: -10rem;
    background: radial-gradient(circle, rgba(212, 162, 74, .24), transparent 70%);
}

body::after {
    bottom: -8rem;
    left: -10rem;
    background: radial-gradient(circle, rgba(139, 149, 171, .18), transparent 70%);
}

::selection {
    color: var(--bs-white);
    background: rgba(var(--bs-primary-rgb), .88);
}

h1,
h2,
h3,
h4,
h5,
h6 {
    color: var(--lux-ink);
    font-family: "Space Grotesk", sans-serif;
    font-weight: 700;
    letter-spacing: -.035em;
}

p,
.lead,
li {
    color: #65584b;
}

.bg-light {
    background-color: #f6f1e8 !important;
}

.text-uppercase.text-primary.bg-light,
.text-uppercase.text-primary.bg-white {
    display: inline-flex;
    align-items: center;
    padding: .5rem .95rem !important;
    border-radius: 999px;
    border: 1px solid rgba(var(--bs-primary-rgb), .18);
    background: rgba(255, 250, 242, .88) !important;
    box-shadow: 0 12px 26px rgba(10, 8, 5, .08);
    color: var(--lux-gold-deep) !important;
    font-family: "Space Grotesk", sans-serif;
    font-size: .8rem;
    font-weight: 700;
    letter-spacing: .16em;
}

.sticky-top {
    z-index: 1030;
}

.navbar {
    padding: 18px 24px;
    border: 1px solid rgba(255, 255, 255, .18);
    border-radius: 28px;
    background: linear-gradient(135deg, rgba(255, 250, 242, .88), rgba(244, 236, 224, .74));
    backdrop-filter: blur(18px) saturate(130%);
    box-shadow: 0 20px 42px rgba(10, 8, 5, .12);
}

.home-hero-nav {
    border-color: rgba(255, 255, 255, .14);
    background: linear-gradient(135deg, rgba(9, 8, 7, .46), rgba(28, 22, 13, .20));
    box-shadow: 0 24px 48px rgba(0, 0, 0, .18);
}

.sticky-top.bg-white .navbar {
    border-color: rgba(var(--bs-primary-rgb), .18);
    background: linear-gradient(135deg, rgba(255, 250, 242, .97), rgba(244, 236, 224, .92));
    box-shadow: 0 22px 48px rgba(10, 8, 5, .16);
}

.navbar-brand img {
    box-shadow:
        0 14px 28px rgba(0, 0, 0, .18),
        0 0 0 6px rgba(255, 250, 242, .08);
}

.navbar-brand h1 {
    font-size: 1.45rem;
    color: var(--lux-ink);
}

.menu-toggle {
    gap: .85rem;
    color: var(--lux-ink);
}

.menu-toggle-text {
    letter-spacing: .14em;
}

.menu-toggle-bars span {
    width: 24px;
}

.menu-overlay-backdrop {
    background: rgba(9, 8, 7, .54);
    backdrop-filter: blur(7px);
}

.menu-overlay-left {
    background:
        linear-gradient(180deg, rgba(9, 8, 7, .88), rgba(33, 24, 11, .80)),
        linear-gradient(145deg, rgba(139, 149, 171, .14), transparent 55%);
    border-right-color: rgba(var(--bs-primary-rgb), .26);
}

.menu-overlay-image-layer {
    background:
        linear-gradient(90deg, rgba(9, 8, 7, .34), rgba(9, 8, 7, 0)),
        linear-gradient(180deg, rgba(139, 149, 171, .10), rgba(9, 8, 7, .24));
}

.btn {
    border-width: 1px;
    box-shadow: 0 10px 24px rgba(10, 8, 5, .08);
}

.btn:hover,
.btn:focus {
    transform: translateY(-2px);
}

.btn-primary {
    color: var(--lux-black);
    border-color: rgba(255, 246, 220, .32);
    background: linear-gradient(135deg, #efc670 0%, #d4a24a 56%, #b17c21 100%);
    box-shadow: 0 16px 30px rgba(150, 103, 29, .24);
}

.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active {
    color: var(--bs-white);
    border-color: rgba(255, 236, 194, .34);
    background: linear-gradient(135deg, #a97421 0%, #c89233 48%, #edc365 100%);
    box-shadow: 0 20px 36px rgba(150, 103, 29, .30);
}

.btn-outline-primary {
    border-color: rgba(var(--bs-primary-rgb), .34);
    background: rgba(255, 250, 242, .58);
    color: var(--lux-gold-deep);
}

.btn-outline-primary:hover,
.btn-outline-primary:focus,
.btn-outline-primary:active {
    color: var(--bs-white);
    border-color: rgba(var(--bs-primary-rgb), .60);
    background: linear-gradient(135deg, rgba(169, 116, 33, .92), rgba(212, 162, 74, .92));
}

.hero-header:not(.ar-hero) {
    position: relative;
    overflow: hidden;
    min-height: 54vh;
    display: flex;
    align-items: flex-end;
    margin-top: -108px;
    padding-top: 215px;
    padding-bottom: 5rem !important;
    background:
        linear-gradient(110deg, rgba(9, 8, 7, .90) 0%, rgba(9, 8, 7, .62) 46%, rgba(9, 8, 7, .74) 100%),
        linear-gradient(145deg, rgba(139, 149, 171, .22), rgba(212, 162, 74, .08)),
        url(../img/project-6.jpg) center center no-repeat;
    background-size: cover;
}

.hero-header:not(.ar-hero)::before {
    position: absolute;
    content: "";
    inset: 0;
    background:
        radial-gradient(circle at 84% 18%, rgba(212, 162, 74, .24), transparent 26%),
        linear-gradient(180deg, rgba(255, 255, 255, .05), transparent 36%);
}

.hero-header:not(.ar-hero)::after {
    position: absolute;
    content: "";
    left: 0;
    right: 0;
    bottom: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(212, 162, 74, .42), transparent);
}

.hero-header:not(.ar-hero) .container {
    position: relative;
    z-index: 1;
}

.hero-header:not(.ar-hero) h1,
.hero-header:not(.ar-hero) .display-1 {
    color: var(--bs-white);
    text-shadow: 0 16px 40px rgba(0, 0, 0, .28);
}

.hero-header:not(.ar-hero) .breadcrumb-item,
.hero-header:not(.ar-hero) .breadcrumb-item.active {
    color: rgba(255, 250, 242, .72) !important;
}

.hero-header:not(.ar-hero) .breadcrumb-item a,
.hero-header:not(.ar-hero) .breadcrumb-item .text-primary {
    color: #edc365 !important;
}

.hero-header .breadcrumb-item + .breadcrumb-item::before {
    color: rgba(255, 250, 242, .44);
}

.ar-hero::before {
    background:
        radial-gradient(circle at top left, rgba(212, 162, 74, .20), transparent 28%),
        linear-gradient(120deg, rgba(7, 7, 7, .52), rgba(7, 7, 7, .20));
}

.ar-hero::after {
    background:
        linear-gradient(90deg, rgba(255, 255, 255, .10) 1px, transparent 1px),
        linear-gradient(rgba(255, 255, 255, .08) 1px, transparent 1px);
    background-size: 140px 140px;
    opacity: .18;
}

.hero-background-overlay {
    background:
        linear-gradient(90deg, rgba(9, 8, 7, .88) 0%, rgba(9, 8, 7, .56) 42%, rgba(9, 8, 7, .28) 100%),
        linear-gradient(180deg, rgba(139, 149, 171, .16), rgba(9, 8, 7, .38));
}

.hero-title {
    max-width: 10.4ch;
    font-size: clamp(3.5rem, 8vw, 6.4rem);
    line-height: .92;
    text-shadow: 0 18px 44px rgba(0, 0, 0, .34);
}

.hero-subtitle {
    max-width: 720px;
    color: rgba(255, 248, 235, .82);
    font-size: clamp(1.02rem, 2vw, 1.32rem);
}

.hero-pills span {
    color: rgba(255, 244, 224, .92);
}

.hero-pills span::before {
    box-shadow: 0 0 0 6px rgba(255, 215, 145, .12);
}

.hero-metric {
    background: linear-gradient(180deg, rgba(255, 250, 242, .12), rgba(255, 250, 242, .06));
    border-color: rgba(255, 235, 190, .16);
    box-shadow: 0 16px 36px rgba(0, 0, 0, .18);
}

.hero-floating-card {
    background:
        linear-gradient(180deg, rgba(255, 250, 242, .92), rgba(244, 236, 225, .88)),
        rgba(255, 250, 242, .86);
    border-left: 4px solid var(--bs-primary);
    box-shadow: 0 24px 46px rgba(0, 0, 0, .18);
}

.hero-floating-card span,
.badge-label,
.project-group-tag,
.project-status,
.project-detail-status {
    color: var(--lux-gold-deep);
    letter-spacing: .12em;
    text-transform: uppercase;
}

.hero-scroll-cue span {
    color: rgba(255, 248, 235, .72);
}

.section-tag,
.hero-eyebrow {
    display: inline-flex !important;
    align-items: center;
    gap: .6rem;
    padding: .55rem 1rem;
    border: 1px solid rgba(var(--bs-primary-rgb), .18);
    background: rgba(255, 250, 242, .82);
    color: var(--lux-gold-deep);
    border-radius: 999px;
    box-shadow: 0 12px 26px rgba(10, 8, 5, .08);
}

.section-tag::before,
.hero-eyebrow::before {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: linear-gradient(135deg, #efc670, #b17c21);
    box-shadow: 0 0 0 5px rgba(var(--bs-primary-rgb), .12);
}

.section-heading {
    position: relative;
    max-width: 760px;
    margin-bottom: 3.2rem;
}

.section-heading::before {
    display: block;
    content: "";
    width: 92px;
    height: 1px;
    margin-bottom: 1.4rem;
    background: linear-gradient(90deg, var(--bs-primary), rgba(139, 149, 171, .26));
}

.section-heading.text-center::before {
    margin-left: auto;
    margin-right: auto;
}

.section-heading h1 {
    font-size: clamp(2.4rem, 4vw, 3.9rem);
    line-height: 1;
}

.section-heading p {
    color: #75695c;
    font-size: 1.05rem;
}

.property-card,
.trust-card,
.service-panel,
.cta-panel,
.simple-project-block,
.project-page-summary-stat,
.project-spotlight-card {
    border: 1px solid rgba(var(--bs-primary-rgb), .14);
    background:
        linear-gradient(180deg, rgba(255, 250, 242, .97), rgba(243, 236, 226, .92));
    box-shadow:
        0 24px 52px rgba(10, 8, 5, .10),
        inset 0 1px 0 rgba(255, 255, 255, .40);
}

.property-card,
.simple-project-block,
.service-panel,
.project-spotlight-card {
    border-radius: 32px;
}

.simple-project-block {
    position: relative;
}

.property-card::after,
.trust-card::after,
.service-item::after,
.simple-project-block::after,
.testimonial-item::after {
    position: absolute;
    content: "";
    inset: 0;
    border-radius: inherit;
    border: 1px solid rgba(255, 255, 255, .22);
    pointer-events: none;
}

.property-card img,
.service-panel img,
.simple-project-block img,
.square img {
    filter: saturate(.88) contrast(1.04);
}

.property-card-body::before,
.project-showcase-card-accent .property-card-body::before {
    width: 92px;
    height: 3px;
    background: linear-gradient(90deg, var(--bs-primary), rgba(139, 149, 171, .28));
}

.trust-card {
    position: relative;
    padding: 2.1rem 1.6rem;
    border-radius: 30px;
}

.trust-card i {
    background:
        linear-gradient(145deg, rgba(212, 162, 74, .16), rgba(139, 149, 171, .14));
    color: var(--lux-gold-deep);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .42);
}

.service-item {
    position: relative;
    padding: 1.6rem;
    border: 1px solid rgba(var(--bs-primary-rgb), .14);
    border-radius: 32px;
    overflow: hidden;
    box-shadow:
        0 24px 48px rgba(10, 8, 5, .10),
        inset 0 1px 0 rgba(255, 255, 255, .34);
}

.service-item.bg-primary {
    background:
        linear-gradient(145deg, rgba(12, 10, 8, .98), rgba(43, 31, 14, .96)) !important;
}

.service-item.bg-primary p {
    color: rgba(255, 248, 235, .78);
}

.service-item.bg-light {
    background:
        linear-gradient(180deg, rgba(255, 250, 242, .98), rgba(241, 233, 221, .94)) !important;
}

.service-item .service-img {
    display: block;
    overflow: hidden;
    border-radius: 24px;
}

.service-item .service-img img {
    height: 240px;
    border-radius: 24px;
    object-fit: cover;
    transition: transform .65s ease;
}

.service-item .service-img h3 {
    top: auto;
    left: 18px;
    bottom: 18px;
    padding: .7rem 1rem;
    border-radius: 999px;
    backdrop-filter: blur(10px);
    box-shadow: 0 12px 24px rgba(0, 0, 0, .16);
}

.service-item:hover .service-img img {
    transform: scale(1.05);
}

.service-item.bg-primary .service-img h3 {
    background: rgba(255, 250, 242, .90);
    color: var(--lux-black);
}

.service-item.bg-light .service-img h3 {
    background: linear-gradient(135deg, rgba(239, 198, 112, .94), rgba(212, 162, 74, .92));
    color: var(--lux-black);
}

.team-item {
    position: relative;
    border-radius: 32px;
    border: 1px solid rgba(var(--bs-primary-rgb), .14);
    background: rgba(255, 250, 242, .30);
    box-shadow: 0 24px 46px rgba(10, 8, 5, .12);
}

.team-item img {
    height: 380px;
    object-fit: cover;
    filter: saturate(.86);
}

.team-overlay {
    padding: 1.8rem;
    background: linear-gradient(180deg, rgba(9, 8, 7, .08) 25%, rgba(9, 8, 7, .94) 100%);
}

.team-overlay small {
    border: 1px solid rgba(var(--bs-primary-rgb), .20);
    background: rgba(255, 250, 242, .12);
    color: var(--bs-primary);
    border-radius: 999px;
    letter-spacing: .1em;
}

.team-overlay .btn-outline-primary {
    color: var(--bs-white);
    border-color: rgba(255, 250, 242, .18);
    background: rgba(255, 250, 242, .08);
}

.team-overlay .btn-outline-primary:hover {
    color: var(--lux-black);
}

.testimonial-item {
    position: relative;
    padding: clamp(1.25rem, 2.8vw, 2rem);
    border: 1px solid rgba(var(--bs-primary-rgb), .14);
    border-radius: 36px;
    background:
        linear-gradient(145deg, rgba(255, 250, 242, .90), rgba(241, 233, 222, .92));
    box-shadow: 0 24px 50px rgba(10, 8, 5, .10);
}

.testimonial-img {
    padding: 0;
    overflow: hidden;
    border-radius: 28px;
    box-shadow: 0 18px 40px rgba(10, 8, 5, .14);
}

.testimonial-img::before {
    display: none;
}

.testimonial-img img {
    width: 100%;
    min-height: 420px;
    border-radius: 28px;
    object-fit: cover;
    filter: saturate(.88);
}

.testimonial-text h5::before {
    background: linear-gradient(90deg, var(--bs-primary), rgba(139, 149, 171, .28));
}

.testimonial-carousel .owl-dot {
    background: rgba(255, 250, 242, .64);
    border-color: rgba(var(--bs-primary-rgb), .55);
}

.testimonial-carousel .owl-dot.active {
    background: linear-gradient(135deg, #efc670, #b17c21);
}

.project-group {
    gap: 2rem;
    padding: clamp(1.25rem, 3vw, 2.2rem);
    border: 1px solid rgba(var(--bs-primary-rgb), .14);
    border-radius: 34px;
    background:
        linear-gradient(145deg, rgba(255, 250, 242, .74), rgba(243, 236, 226, .92));
    box-shadow: 0 22px 48px rgba(10, 8, 5, .08);
}

.project-group-tag {
    display: inline-flex;
    align-items: center;
    gap: .55rem;
    padding: .52rem .9rem;
    border: 1px solid rgba(var(--bs-primary-rgb), .18);
    border-radius: 999px;
    background: rgba(255, 250, 242, .84);
}

.project-group-tag::before {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: linear-gradient(135deg, #efc670, #b17c21);
}

.project-group-copy p {
    color: #6e6255;
}

.medium.row {
    min-height: 390px;
}

.square {
    border-radius: 30px;
    border-color: rgba(var(--bs-primary-rgb), .16);
    box-shadow:
        0 20px 42px rgba(10, 8, 5, .14),
        inset 0 1px 0 rgba(255, 255, 255, .20);
    background: linear-gradient(180deg, rgba(255, 250, 242, .98), rgba(243, 236, 226, .92));
}

.square img {
    height: 360px;
}

#project-trigger::after,
#project-trigger-second::after,
#project-trigger-third::after {
    background: rgba(9, 8, 7, .72);
    border: 1px solid rgba(var(--bs-primary-rgb), .18);
}

.project-detail-page {
    background:
        radial-gradient(circle at top left, rgba(139, 149, 171, .20), transparent 24%),
        radial-gradient(circle at bottom right, rgba(212, 162, 74, .12), transparent 18%),
        linear-gradient(180deg, #090807 0%, #11100d 56%, #1a150e 100%);
}

.project-detail-name {
    color: var(--bs-white);
    font-family: "Space Grotesk", sans-serif;
    font-weight: 700;
    letter-spacing: -.05em;
    text-shadow: 0 16px 36px rgba(0, 0, 0, .24);
}

.project-detail-copy {
    color: rgba(255, 248, 235, .80);
}

.project-detail-fact,
.project-page-summary-stat {
    border-color: rgba(var(--bs-primary-rgb), .18);
    background: linear-gradient(180deg, rgba(255, 250, 242, .12), rgba(139, 149, 171, .10));
}

.project-detail-media {
    background: rgba(255, 250, 242, .06);
    border: 1px solid rgba(var(--bs-primary-rgb), .14);
}

.project-page-hero-overlay {
    background:
        linear-gradient(90deg, rgba(9, 8, 7, .88) 0%, rgba(9, 8, 7, .58) 48%, rgba(9, 8, 7, .76) 100%),
        radial-gradient(circle at 80% 20%, rgba(212, 162, 74, .20), transparent 26%);
}

.project-spotlight-badge {
    border: 1px solid rgba(var(--bs-primary-rgb), .16);
}

.newsletter {
    position: relative;
    overflow: hidden;
    background:
        linear-gradient(110deg, rgba(9, 8, 7, .94), rgba(34, 25, 12, .92)),
        url(../img/project-11.jpg) center center no-repeat;
    background-size: cover;
    border-top: 1px solid rgba(var(--bs-primary-rgb), .22);
    border-bottom: 1px solid rgba(var(--bs-primary-rgb), .18);
}

.newsletter::before {
    position: absolute;
    content: "";
    inset: 0;
    background:
        radial-gradient(circle at 80% 20%, rgba(212, 162, 74, .24), transparent 24%),
        linear-gradient(180deg, rgba(139, 149, 171, .10), transparent 55%);
    pointer-events: none;
}

.newsletter .container,
.newsletter .row,
.newsletter .newsletter-text {
    position: relative;
    z-index: 1;
}

.newsletter img {
    height: 100%;
    min-height: 100%;
    object-fit: cover;
    filter: saturate(.82) contrast(1.02);
}

.newsletter h1,
.newsletter h2,
.newsletter p,
.newsletter span:not(.text-primary) {
    color: rgba(255, 248, 235, .92);
}

.newsletter .form-control {
    border: 1px solid rgba(255, 255, 255, .16);
    border-radius: 999px;
    background: rgba(255, 250, 242, .94);
    box-shadow: 0 16px 36px rgba(0, 0, 0, .14);
}

.newsletter button.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: linear-gradient(135deg, #efc670, #b17c21);
}

.newsletter button.btn i {
    color: var(--lux-black) !important;
}

.footer {
    position: relative;
    overflow: hidden;
    background:
        radial-gradient(circle at top right, rgba(212, 162, 74, .14), transparent 18%),
        linear-gradient(180deg, #090807 0%, #13100b 52%, #1e180f 100%) !important;
    border-top: 1px solid rgba(var(--bs-primary-rgb), .18);
}

.footer::before {
    position: absolute;
    content: "";
    inset: 0;
    background:
        linear-gradient(90deg, rgba(255, 255, 255, .04) 1px, transparent 1px),
        linear-gradient(rgba(255, 255, 255, .03) 1px, transparent 1px);
    background-size: 140px 140px;
    opacity: .16;
    mask-image: linear-gradient(180deg, rgba(0, 0, 0, .45), transparent 85%);
    pointer-events: none;
}

.footer > .container {
    position: relative;
    z-index: 1;
}

.footer h1,
.footer h5 {
    color: var(--bs-white);
}

.footer p,
.footer a,
.footer .copyright,
.footer .copyright a {
    color: rgba(255, 248, 235, .68);
}

.footer .btn-outline-primary {
    background: rgba(255, 250, 242, .06);
    color: var(--bs-primary);
}

.footer .btn-outline-primary:hover {
    color: var(--lux-black);
}

.footer .btn.btn-link {
    color: rgba(255, 248, 235, .70);
}

.footer .btn.btn-link:hover,
.footer .copyright a:hover,
.footer-menu a:hover {
    color: var(--bs-white);
}

.footer .copyright {
    border-top-color: rgba(var(--bs-primary-rgb), .18);
}

.form-floating > .form-control,
.form-floating > .form-select,
textarea.form-control {
    border: 1px solid rgba(120, 103, 75, .14);
    border-radius: 22px;
    background: rgba(255, 250, 242, .82);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, .44),
        0 14px 30px rgba(10, 8, 5, .05);
}

.form-floating > .form-control {
    min-height: 62px;
}

.form-floating > label {
    color: #7c6e5f;
}

.form-control:focus,
.form-select:focus {
    background: rgba(255, 250, 242, .96);
    border-color: rgba(var(--bs-primary-rgb), .34);
    box-shadow:
        0 0 0 .24rem rgba(var(--bs-primary-rgb), .14),
        0 18px 34px rgba(10, 8, 5, .08);
}

.back-to-top {
    right: 24px;
    bottom: 24px;
    box-shadow: 0 18px 36px rgba(150, 103, 29, .28);
}

@media (max-width: 991.98px) {
    body::before,
    body::after {
        width: 18rem;
        height: 18rem;
        opacity: .42;
    }

    .sticky-top {
        top: 0 !important;
    }

    .navbar {
        padding: 14px 16px;
    }

    .navbar-brand {
        display: flex;
        align-items: center;
        gap: .75rem !important;
        min-width: 0;
        max-width: calc(100% - 96px);
    }

    .navbar-brand img {
        width: 46px;
        height: 46px;
        flex-shrink: 0;
    }

    .navbar-brand h1,
    .navbar-brand h1.mb-0 {
        margin: 0;
        font-size: 1.08rem;
        line-height: 1.15;
        letter-spacing: .04em;
        white-space: normal;
        overflow-wrap: anywhere;
    }

    .menu-toggle {
        flex-shrink: 0;
        margin-left: .75rem !important;
        padding: .55rem 0;
    }

    .hero-header:not(.ar-hero) {
        min-height: auto;
        padding-top: 190px;
    }

    .section-heading {
        margin-bottom: 2.2rem;
    }

    .project-group {
        padding: 1.4rem;
    }

    .testimonial-img img,
    .team-item img {
        min-height: 280px;
        height: 280px;
    }
}

@media (max-width: 575.98px) {
    .sticky-top > .container {
        padding-left: 12px;
        padding-right: 12px;
    }

    .navbar {
        padding: 12px 14px;
        border-radius: 20px;
    }

    .navbar-brand {
        gap: .6rem !important;
        max-width: calc(100% - 58px);
    }

    .navbar-brand img {
        width: 40px;
        height: 40px;
    }

    .navbar-brand h1.mb-0 {
        font-size: .9rem;
        letter-spacing: .03em;
    }

    .menu-toggle {
        min-width: 44px;
        justify-content: center;
        gap: 0;
        font-size: .88rem;
    }

    .menu-toggle-text {
        display: none;
    }

    .menu-overlay-head {
        gap: 1rem;
        align-items: flex-start;
    }

    .menu-overlay-head .navbar-brand {
        max-width: calc(100% - 56px);
    }

    .menu-overlay-left {
        padding: 1.15rem 1rem 1.5rem;
    }

    .hero-header:not(.ar-hero) {
        margin-top: -112px;
        padding-top: 178px;
        padding-bottom: 4rem !important;
    }

    .hero-title {
        font-size: clamp(3rem, 15vw, 4.4rem);
    }

    .hero-pills span {
        width: 100%;
        justify-content: flex-start;
    }

    .hero-pills {
        grid-template-columns: 1fr;
        max-width: none;
    }

    .property-card img,
    .service-panel img,
    .simple-project-block img,
    .service-item .service-img img,
    .square img {
        height: 240px;
    }

    .project-group {
        padding: 1rem;
        border-radius: 28px;
    }

    .testimonial-item {
        padding: 1rem;
    }

    .newsletter .p-5 {
        padding: 2rem !important;
    }
}

body.project-page {
    background:
        radial-gradient(circle at 12% 0%, rgba(212, 162, 74, .22), transparent 24%),
        radial-gradient(circle at 94% 10%, rgba(139, 149, 171, .14), transparent 20%),
        linear-gradient(180deg, #090807 0%, #140f0a 18%, #f1e9dd 18%, #f7f1e7 100%);
    background-attachment: fixed;
}

body.project-page::before {
    top: 4rem;
    right: -8rem;
    width: 34rem;
    height: 34rem;
    background: radial-gradient(circle, rgba(212, 162, 74, .22), transparent 68%);
}

body.project-page::after {
    bottom: 6rem;
    left: -10rem;
    width: 30rem;
    height: 30rem;
    background: radial-gradient(circle, rgba(139, 149, 171, .16), transparent 72%);
}

.project-page .hero-header:not(.ar-hero) {
    background:
        linear-gradient(115deg, rgba(8, 7, 6, .94) 0%, rgba(8, 7, 6, .66) 42%, rgba(21, 15, 10, .82) 100%),
        radial-gradient(circle at 82% 20%, rgba(212, 162, 74, .24), transparent 24%),
        url(../img/project-10.jpg) center center no-repeat;
    background-size: cover;
}

.project-page .hero-header:not(.ar-hero)::before {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, .05), transparent 34%),
        radial-gradient(circle at 18% 78%, rgba(139, 149, 171, .18), transparent 26%);
}

.project-page .hero-header:not(.ar-hero)::after {
    background: linear-gradient(90deg, transparent, rgba(212, 162, 74, .54), transparent);
}

.project-page-main {
    position: relative;
    overflow: hidden;
    background:
        linear-gradient(180deg, rgba(9, 8, 7, .98) 0%, rgba(15, 12, 9, .94) 14rem, rgba(248, 242, 232, .98) 14rem, rgba(244, 236, 226, .98) 100%);
}

.project-page-main::before {
    position: absolute;
    content: "";
    inset: 0;
    background:
        radial-gradient(circle at 8% 10%, rgba(212, 162, 74, .18), transparent 18%),
        radial-gradient(circle at 92% 12%, rgba(139, 149, 171, .14), transparent 18%),
        linear-gradient(90deg, rgba(255, 255, 255, .04) 1px, transparent 1px),
        linear-gradient(rgba(255, 255, 255, .03) 1px, transparent 1px);
    background-size: auto, auto, 120px 120px, 120px 120px;
    opacity: .22;
    mask-image: linear-gradient(180deg, rgba(0, 0, 0, .95), rgba(0, 0, 0, .25) 18rem, transparent 28rem);
    pointer-events: none;
}

.project-page-main::after {
    position: absolute;
    content: "";
    inset: auto 0 0;
    height: 28rem;
    background:
        radial-gradient(circle at 15% 100%, rgba(212, 162, 74, .08), transparent 30%),
        radial-gradient(circle at 88% 0%, rgba(139, 149, 171, .10), transparent 24%);
    pointer-events: none;
}

.project-page-main > .container {
    position: relative;
    z-index: 1;
}

.project-page-intro {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(0, .85fr);
    gap: 1.5rem;
    align-items: start;
    padding: clamp(1.6rem, 4vw, 2.5rem);
    border: 1px solid rgba(var(--bs-primary-rgb), .18);
    border-radius: 36px;
    background:
        linear-gradient(135deg, rgba(10, 8, 6, .92), rgba(33, 24, 13, .86)),
        radial-gradient(circle at top right, rgba(212, 162, 74, .16), transparent 24%);
    box-shadow: 0 30px 60px rgba(0, 0, 0, .26);
}

.project-page-kicker {
    display: inline-flex;
    align-items: center;
    gap: .65rem;
    margin-bottom: 1rem;
    padding: .55rem 1rem;
    border: 1px solid rgba(var(--bs-primary-rgb), .22);
    border-radius: 999px;
    background: rgba(255, 250, 242, .10);
    color: rgba(255, 248, 235, .88);
    font-family: "Space Grotesk", sans-serif;
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .18em;
    text-transform: uppercase;
}

.project-page-kicker::before {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: linear-gradient(135deg, #efc670, #b17c21);
    box-shadow: 0 0 0 5px rgba(var(--bs-primary-rgb), .12);
}

.project-page-intro h2 {
    color: var(--bs-white);
}

.project-page-intro p {
    max-width: 58ch;
    color: rgba(255, 248, 235, .78);
    font-size: 1.02rem;
    line-height: 1.8;
}

.project-page-metrics {
    display: grid;
    grid-template-columns: 1fr;
    gap: .85rem;
}

.project-page-metric {
    padding: 1rem 1.1rem;
    border: 1px solid rgba(var(--bs-primary-rgb), .16);
    border-radius: 22px;
    background: linear-gradient(180deg, rgba(255, 250, 242, .10), rgba(139, 149, 171, .08));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .14);
}

.project-page-metric strong {
    display: block;
    margin-bottom: .35rem;
    color: var(--bs-white);
    font-family: "Space Grotesk", sans-serif;
    font-size: 1rem;
    letter-spacing: .02em;
}

.project-page-metric span {
    display: block;
    color: rgba(255, 248, 235, .68);
    font-size: .92rem;
    line-height: 1.6;
}

.project-page .project-group {
    position: relative;
    overflow: hidden;
    grid-template-columns: minmax(0, .92fr) minmax(0, 1.08fr);
    align-items: stretch;
    gap: clamp(1.4rem, 3vw, 2.4rem);
    padding: clamp(1.4rem, 3vw, 2.2rem);
    border: 1px solid rgba(var(--bs-primary-rgb), .14);
    border-radius: 40px;
    background:
        linear-gradient(145deg, rgba(255, 250, 242, .86), rgba(242, 234, 223, .98));
    box-shadow:
        0 28px 58px rgba(10, 8, 5, .12),
        inset 0 1px 0 rgba(255, 255, 255, .46);
}

.project-page .project-group::before {
    position: absolute;
    content: "";
    left: 1.5rem;
    right: 1.5rem;
    top: 1.25rem;
    height: 1px;
    background: linear-gradient(90deg, rgba(212, 162, 74, .12), rgba(212, 162, 74, .5), transparent 76%);
}

.project-page .project-group::after {
    position: absolute;
    content: "";
    top: -4rem;
    right: -2rem;
    width: 12rem;
    height: 12rem;
    background: radial-gradient(circle, rgba(212, 162, 74, .14), transparent 72%);
    pointer-events: none;
    filter: blur(18px);
}

.project-page .project-group:hover {
    transform: translateY(-4px);
    box-shadow:
        0 34px 68px rgba(10, 8, 5, .15),
        inset 0 1px 0 rgba(255, 255, 255, .46);
}

.project-page .project-group-copy,
.project-page .projects-animation-wrap {
    position: relative;
    z-index: 1;
    transition: transform .45s ease, box-shadow .45s ease, border-color .45s ease;
}

.project-page .project-group:hover .project-group-copy {
    transform: none;
}

.project-page .project-group:hover .projects-animation-wrap {
    transform: none;
}

.project-page .project-group-copy {
    overflow: hidden;
    max-width: none;
    margin: 0;
    padding: clamp(1.9rem, 3vw, 2.6rem);
    padding-right: clamp(1.6rem, 2vw, 2.2rem);
    border: 1px solid rgba(var(--bs-primary-rgb), .18);
    border-radius: 30px;
    background:
        linear-gradient(155deg, rgba(10, 8, 6, .95), rgba(39, 28, 14, .88)),
        radial-gradient(circle at top right, rgba(212, 162, 74, .16), transparent 28%);
    box-shadow:
        0 28px 56px rgba(10, 8, 5, .22),
        inset 0 1px 0 rgba(255, 255, 255, .08);
}

.project-page .project-group-copy::before {
    position: absolute;
    content: "";
    left: 1.4rem;
    top: 1.4rem;
    width: 4.75rem;
    height: 1px;
    background: linear-gradient(90deg, rgba(212, 162, 74, .78), rgba(212, 162, 74, 0));
}

.project-page .project-group-copy::after {
    position: absolute;
    content: "";
    right: -2rem;
    bottom: -2rem;
    width: 8.5rem;
    height: 8.5rem;
    background: radial-gradient(circle, rgba(212, 162, 74, .18), transparent 70%);
    pointer-events: none;
}

.project-group-number {
    position: absolute;
    top: 1.2rem;
    right: 1.35rem;
    color: rgba(255, 248, 235, .08);
    font-family: "Space Grotesk", sans-serif;
    font-size: clamp(3rem, 6vw, 4.4rem);
    font-weight: 700;
    line-height: .9;
    letter-spacing: -.05em;
    pointer-events: none;
}

.project-page .project-group-copy h3 {
    font-size: clamp(2rem, 4vw, 3rem);
    color: var(--bs-white);
    max-width: 12ch;
}

.project-page .project-group-copy p {
    color: rgba(255, 248, 235, .76);
    max-width: 38ch;
    font-size: 1.02rem;
    line-height: 1.82;
}

.project-page .projects-animation-wrap {
    overflow: hidden;
    padding: 1.25rem;
    border: 1px solid rgba(var(--bs-primary-rgb), .14);
    border-radius: 32px;
    background:
        linear-gradient(160deg, rgba(255, 250, 242, .94), rgba(238, 228, 214, .92));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .46);
}

.project-page .medium.row {
    min-height: 370px;
    justify-content: flex-start;
}

.project-page .projects-animation-wrap::before {
    position: absolute;
    content: "";
    left: 1.25rem;
    right: 1.25rem;
    top: 1.25rem;
    height: 1px;
    background: linear-gradient(90deg, rgba(212, 162, 74, .18), rgba(212, 162, 74, .52), transparent 72%);
}

.project-page .projects-animation-wrap::after {
    position: absolute;
    content: "";
    bottom: 1rem;
    right: 1rem;
    width: 4rem;
    height: 4rem;
    border: 1px solid rgba(var(--bs-primary-rgb), .18);
    border-radius: 24px;
    opacity: .38;
    pointer-events: none;
}

.project-page .square {
    width: 11.5rem;
    background: linear-gradient(180deg, rgba(255, 250, 242, .98), rgba(241, 232, 220, .94));
    border-color: rgba(var(--bs-primary-rgb), .18);
    box-shadow:
        0 22px 46px rgba(10, 8, 5, .16),
        inset 0 1px 0 rgba(255, 255, 255, .22);
}

.project-page #project-trigger,
.project-page #project-trigger-second,
.project-page #project-trigger-third {
    width: 15rem;
}

.project-page .project-static-visual .medium.row {
    min-height: 320px;
    justify-content: center;
}

.project-page .project-static-card {
    width: 15rem;
}

.project-page .square img {
    filter: saturate(.9) contrast(1.05);
}

.project-page .square[role="button"] {
    cursor: pointer;
}

.project-page .square[role="button"]:focus-visible {
    outline: 2px solid rgba(var(--bs-primary-rgb), .55);
    outline-offset: 6px;
}

.project-page .project-group-tag {
    background: rgba(255, 250, 242, .10);
    color: rgba(255, 248, 235, .88);
    border-color: rgba(var(--bs-primary-rgb), .22);
}

.project-page .project-group-tag.status-in-progress {
    color: #f4c152;
    background: rgba(244, 193, 82, .14);
    border-color: rgba(244, 193, 82, .3);
}

.project-page .project-group-tag.status-finished {
    color: #7fd39a;
    background: rgba(127, 211, 154, .16);
    border-color: rgba(127, 211, 154, .32);
}

.project-page .project-group-tag.status-study {
    color: #8ec5ff;
    background: rgba(142, 197, 255, .16);
    border-color: rgba(142, 197, 255, .34);
}

.project-page .project-group-copy .btn-outline-primary {
    color: var(--bs-white);
    border-color: rgba(var(--bs-primary-rgb), .34);
    background: rgba(255, 250, 242, .06);
}

.project-page .project-group-copy .btn-outline-primary:hover,
.project-page .project-group-copy .btn-outline-primary:focus {
    color: var(--lux-black);
    border-color: rgba(var(--bs-primary-rgb), .60);
    background: linear-gradient(135deg, #efc670, #c79032);
}

.project-page .project-group-reverse {
    grid-template-columns: minmax(0, .92fr) minmax(0, 1.08fr);
}

.project-page .project-group-reverse::before {
    left: 1.5rem;
    right: 1.5rem;
    top: 1.25rem;
    height: 1px;
    border-radius: 0;
}

.project-page .project-group-reverse::after {
    right: -2rem;
    left: auto;
}

.project-page .project-group-reverse .project-group-copy {
    order: initial;
    margin: 0;
    border-radius: 30px;
}

.project-page .project-group-reverse .project-group-copy::before {
    left: 1.4rem;
    right: auto;
    background: linear-gradient(90deg, rgba(212, 162, 74, .78), rgba(212, 162, 74, 0));
}

.project-page .project-group-reverse .project-group-copy::after {
    right: -2rem;
    left: auto;
}

.project-page .project-group-reverse .project-group-number {
    right: 1.35rem;
    left: auto;
}

.project-page .project-group-reverse .projects-animation-wrap {
    order: initial;
    padding: 1.25rem;
}

.project-page .project-group-reverse .medium.row {
    justify-content: flex-start;
}

.project-page .project-group-reverse .projects-animation-wrap::before {
    left: 1.25rem;
    right: 1.25rem;
}

.project-page .project-group-reverse .projects-animation-wrap::after {
    right: 1rem;
    left: auto;
}

@media (min-width: 992px) {
    .project-page #project-fourth,
    .project-page #project-fifth,
    .project-page #project-nine,
    .project-page #project-thirteen {
        display: none;
    }

    .project-page .reveal-square {
        top: 50%;
        left: 0;
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
        filter: saturate(.86) brightness(.98);
        transform: translate3d(13.2rem, -50%, 0) scale(.88) rotate(-3deg);
        transform-origin: center center;
        transition:
            transform .6s cubic-bezier(.22, 1, .36, 1),
            opacity .28s ease,
            filter .28s ease,
            visibility 0s linear .28s;
    }

    .project-page .reveal-square.is-visible {
        visibility: visible;
        pointer-events: auto;
        box-shadow:
            0 20px 40px rgba(10, 8, 5, .14),
            inset 0 1px 0 rgba(255, 255, 255, .22);
        transition:
            transform .6s cubic-bezier(.22, 1, .36, 1),
            opacity .28s ease,
            filter .28s ease,
            visibility 0s linear 0s;
    }

    .project-page #project-trigger,
    .project-page #project-trigger-second,
    .project-page #project-trigger-third {
        transition: transform .55s cubic-bezier(.22, 1, .36, 1), box-shadow .55s ease, filter .55s ease;
    }

    .project-page #project-trigger::after,
    .project-page #project-trigger-second::after,
    .project-page #project-trigger-third::after {
        content: "Survolez pour voir deux autres visuels";
        padding: .68rem 1rem;
        font-size: .74rem;
        letter-spacing: .1em;
    }

    .project-page #project-third,
    .project-page #project-eight,
    .project-page #project-twelve {
        filter: saturate(.82) brightness(.96);
        transform: translate3d(20.5rem, -50%, 0) scale(.82) rotate(5deg);
    }

    .project-page .projects-animation-wrap.projects-open #project-trigger,
    .project-page .projects-animation-wrap.projects-open #project-trigger-second,
    .project-page .projects-animation-wrap.projects-open #project-trigger-third {
        transform: translate3d(-.12rem, 0, 0) scale(.985);
        box-shadow:
            0 16px 34px rgba(10, 8, 5, .14),
            inset 0 1px 0 rgba(255, 255, 255, .22);
        filter: saturate(.94);
    }

    .project-page #projects-animation-wrap.projects-open #css-selector-id,
    .project-page #projects-animation-wrap-second.projects-open #project-seven,
    .project-page #projects-animation-wrap-third.projects-open #project-eleven {
        opacity: 1;
        filter: saturate(1) brightness(1.02);
        transform: translate3d(16rem, -50%, 0) scale(.96) rotate(2deg);
    }

    .project-page #projects-animation-wrap.projects-open #project-third,
    .project-page #projects-animation-wrap-second.projects-open #project-eight,
    .project-page #projects-animation-wrap-third.projects-open #project-twelve {
        opacity: 1;
        filter: saturate(.95) brightness(1);
        transform: translate3d(24.5rem, -50%, 0) scale(.88) rotate(5deg);
        transition-delay: .08s;
    }
}

.project-page #project-trigger::after,
.project-page #project-trigger-second::after,
.project-page #project-trigger-third::after {
    background: linear-gradient(135deg, rgba(9, 8, 7, .88), rgba(40, 29, 14, .78));
    border-color: rgba(var(--bs-primary-rgb), .24);
    backdrop-filter: blur(8px);
}

.project-gallery-close {
    display: none;
    align-items: center;
    justify-content: center;
    margin-top: 1rem;
    padding: .9rem 1.1rem;
    border: 1px solid rgba(var(--bs-primary-rgb), .28);
    border-radius: 999px;
    background: linear-gradient(135deg, rgba(13, 10, 8, .94), rgba(37, 27, 14, .90));
    color: var(--bs-white);
    font-family: "Space Grotesk", sans-serif;
    font-size: .8rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    box-shadow: 0 16px 32px rgba(10, 8, 5, .16);
}

.project-gallery-close:hover,
.project-gallery-close:focus {
    color: var(--bs-white);
    border-color: rgba(var(--bs-primary-rgb), .52);
    background: linear-gradient(135deg, rgba(169, 116, 33, .94), rgba(212, 162, 74, .94));
}

.project-lightbox {
    position: fixed;
    inset: 0;
    z-index: 2100;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity .3s ease, visibility 0s linear .3s;
}

.project-lightbox.is-open {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transition: opacity .3s ease, visibility 0s linear 0s;
}

.project-lightbox-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(9, 8, 7, .82);
    backdrop-filter: blur(12px);
}

.project-lightbox-panel {
    position: relative;
    z-index: 1;
    width: min(92vw, 1040px);
    padding: 1rem;
    border: 1px solid rgba(var(--bs-primary-rgb), .18);
    border-radius: 32px;
    background: linear-gradient(180deg, rgba(18, 14, 10, .96), rgba(40, 29, 15, .92));
    box-shadow: 0 32px 72px rgba(0, 0, 0, .38);
}

.project-lightbox-frame {
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, .08);
    border-radius: 24px;
    background: rgba(255, 250, 242, .04);
}

.project-lightbox-frame img {
    display: block;
    width: 100%;
    max-height: 78vh;
    object-fit: contain;
    background: #050403;
}

.project-lightbox-caption {
    padding: 1rem .4rem .2rem;
    color: rgba(255, 248, 235, .82);
    font-family: "Space Grotesk", sans-serif;
    font-size: .98rem;
    letter-spacing: .04em;
}

.project-lightbox-close {
    position: absolute;
    top: 1rem;
    right: 1rem;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3rem;
    height: 3rem;
    border: 1px solid rgba(var(--bs-primary-rgb), .30);
    border-radius: 50%;
    background: rgba(255, 250, 242, .08);
    color: var(--bs-white);
    font-size: 2rem;
    line-height: 1;
}

.project-lightbox-close:hover,
.project-lightbox-close:focus {
    color: var(--lux-black);
    background: var(--bs-primary);
    border-color: var(--bs-primary);
}

body.project-lightbox-open {
    overflow: hidden;
}

@media (max-width: 991.98px) {
    body.project-page {
        background-attachment: scroll;
    }

    .project-page-intro {
        grid-template-columns: 1fr;
    }

    .project-page .project-group,
    .project-page .project-group-reverse {
        grid-template-columns: 1fr;
        gap: 1.2rem;
        padding: 1.25rem;
        border-radius: 34px;
    }

    .project-page .project-group::before,
    .project-page .project-group-reverse::before {
        left: 1.25rem;
        right: 1.25rem;
        top: 1rem;
        height: 1px;
        border-radius: 0;
    }

    .project-page .project-group::after,
    .project-page .project-group-reverse::after {
        top: -4rem;
        left: auto;
        right: -2rem;
    }

    .project-page .project-group-copy,
    .project-page .project-group-reverse .project-group-copy,
    .project-page .project-group-reverse .projects-animation-wrap {
        order: initial;
    }

    .project-page .project-group-copy,
    .project-page .project-group-reverse .project-group-copy {
        max-width: none;
        margin: 0;
        border-radius: 34px;
    }

    .project-page .project-group-copy::before,
    .project-page .project-group-reverse .project-group-copy::before {
        left: 1.2rem;
        right: auto;
        background: linear-gradient(90deg, rgba(212, 162, 74, .78), rgba(212, 162, 74, 0));
    }

    .project-page .project-group-number,
    .project-page .project-group-reverse .project-group-number {
        right: 1.25rem;
        left: auto;
        font-size: clamp(3.2rem, 14vw, 5rem);
    }

    .project-page .projects-animation-wrap,
    .project-page .project-group-reverse .projects-animation-wrap {
        padding: 1.2rem;
    }

    .project-page .projects-animation-wrap::before,
    .project-page .project-group-reverse .projects-animation-wrap::before {
        left: 1.3rem;
        right: 1.3rem;
        top: 1.3rem;
    }

    .project-page .projects-animation-wrap::after,
    .project-page .project-group-reverse .projects-animation-wrap::after {
        right: 1.2rem;
        left: auto;
    }
}

@media (max-width: 767.98px) {
    .project-page-main {
        padding-top: 0;
    }

    .project-page-intro {
        padding: 1.3rem;
        border-radius: 28px;
    }

    .project-page-intro p {
        font-size: .98rem;
    }

    .project-page-metrics {
        grid-template-columns: 1fr;
    }

    .project-page .project-group {
        padding: 1rem;
        border-radius: 28px;
    }

    .project-page .project-group-copy {
        padding: 1.45rem 1.2rem 1.5rem;
        border-radius: 30px;
    }

    .project-page .project-group-copy::before {
        left: 1rem;
        top: 1rem;
    }

    .project-page .project-group-copy h3 {
        max-width: none;
        font-size: clamp(2rem, 9vw, 2.9rem);
    }

    .project-page .project-group-copy p {
        max-width: none;
        font-size: .98rem;
    }

    .project-page .projects-animation-wrap {
        padding: 1rem;
        border-radius: 30px;
    }

    .projects-animation-wrap.projects-open .project-gallery-close {
        display: inline-flex;
        width: 100%;
    }

    .project-lightbox {
        padding: 1rem;
    }

    .project-lightbox-panel {
        width: min(94vw, 540px);
        padding: .85rem;
        border-radius: 28px;
    }

    .project-lightbox-frame img {
        max-height: 68vh;
    }

    .project-lightbox-caption {
        padding: .85rem .2rem .1rem;
        font-size: .92rem;
    }
}

@media (max-width: 575.98px) {
    .project-page .hero-header:not(.ar-hero) {
        background-position: 58% center;
    }

    .project-page-kicker {
        font-size: .72rem;
        letter-spacing: .16em;
    }

    .project-page-intro h2 {
        font-size: clamp(2rem, 10vw, 2.8rem);
    }
}

.contact-page .hero-header:not(.ar-hero) {
    min-height: auto;
    align-items: center;
    padding-top: 190px;
    padding-bottom: 3rem !important;
    background: transparent;
}

.contact-page .hero-header:not(.ar-hero)::before,
.contact-page .hero-header:not(.ar-hero)::after {
    display: none;
}

.contact-page .hero-header:not(.ar-hero) h1,
.contact-page .hero-header:not(.ar-hero) .display-1 {
    color: var(--lux-ink);
    text-shadow: none;
}

.contact-page .hero-header:not(.ar-hero) .breadcrumb-item,
.contact-page .hero-header:not(.ar-hero) .breadcrumb-item.active {
    color: #7f7262 !important;
}

.contact-page .hero-header:not(.ar-hero) .breadcrumb-item a,
.contact-page .hero-header:not(.ar-hero) .breadcrumb-item .text-primary {
    color: var(--lux-gold-deep) !important;
}

.contact-page .hero-header .breadcrumb-item + .breadcrumb-item::before {
    color: rgba(95, 86, 72, .42);
}
