@charset "UTF-8";

:root {
    --maison-navy: #061f5f;
    --maison-ink: #101936;
    --maison-blue: #264f92;
    --maison-paper: #f4f7fb;
    --maison-cream: #f1eee7;
    --maison-gold: #c89b61;
    --maison-muted: #6b7280;
}

* {
    box-sizing: border-box;
}

body.maison_landing {
    min-height: 100vh;
    margin: 0;
    font-family: Arial, Helvetica, sans-serif;
    color: var(--maison-ink);
    background: #f7f2ea;
}

.maison_header {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    z-index: 10;
    padding: 24px clamp(20px, 5vw, 72px);
}

.maison_header_content {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
}

.maison_brand {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    color: #fff;
    font-family: Georgia, "Times New Roman", serif;
    font-size: clamp(1.05rem, 2vw, 1.35rem);
    font-weight: 700;
    text-decoration: none;
}

.maison_brand img {
    width: 44px;
    height: 44px;
    object-fit: contain;
    filter: contrast(1.15) saturate(1.05);
}

.maison_login {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 12px 20px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, .45);
    background: rgba(255, 255, 255, .12);
    color: #fff;
    font-weight: 700;
    text-decoration: none;
    box-shadow: 0 14px 35px rgba(0, 0, 0, .16);
    backdrop-filter: blur(12px);
}

.maison_hero {
    position: relative;
    isolation: isolate;
    min-height: 100vh;
    display: flex;
    align-items: center;
    width: 100%;
    margin: 0;
    padding: 130px clamp(24px, 8vw, 160px) 72px;
    overflow: hidden;
    background: #130d16;
}

.maison_hero_text {
    position: relative;
    z-index: 2;
    max-width: 580px;
    color: #fff;
}

.maison_eyebrow {
    margin: 0 0 18px;
    color: #e6c07a;
    font-size: .78rem;
    font-weight: 800;
    letter-spacing: .14em;
    text-transform: uppercase;
}

.maison_hero h1 {
    margin: 0;
    color: #fff;
    font-family: Georgia, "Times New Roman", serif;
    font-size: clamp(2.35rem, 4.25vw, 4.65rem);
    line-height: 1.05;
    letter-spacing: 0;
}

.maison_hero p {
    margin: 24px 0 0;
    color: rgba(255, 255, 255, .86);
    font-size: clamp(1rem, 1.5vw, 1.2rem);
    line-height: 1.7;
}

.maison_cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: 34px;
    min-height: 50px;
    padding: 14px 24px;
    border-radius: 999px;
    background: #c8943d;
    color: #fff;
    font-weight: 800;
    text-decoration: none;
}

.maison_hero_media {
    position: absolute;
    inset: 0;
    z-index: 0;
    min-height: 100%;
    margin: 0;
    border-radius: 0;
    overflow: hidden;
    background: radial-gradient(circle at 74% 45%, rgba(200, 155, 97, .18), transparent 30%),
        linear-gradient(110deg, #130d16 0%, #351c32 48%, #07183e 100%);
    box-shadow: none;
}

.maison_hero_media::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    background:
        linear-gradient(90deg, rgba(8, 8, 16, .84) 0%, rgba(25, 12, 30, .66) 37%, rgba(25, 12, 30, .16) 62%, rgba(0, 0, 0, .08) 100%),
        linear-gradient(0deg, rgba(0, 0, 0, .25), transparent 42%);
}

.maison_hero_media img {
    width: 100%;
    height: 100%;
    min-height: inherit;
    object-fit: cover;
    object-position: left center;
    display: block;
}

.maison_hero_placeholder {
    height: 100%;
    min-height: inherit;
    display: grid;
    place-items: center;
    padding: 44px;
    color: rgba(255, 255, 255, .82);
    text-align: center;
}

.maison_hero_placeholder img {
    width: min(220px, 48vw);
    height: auto;
    min-height: 0;
    opacity: .2;
    filter: brightness(2);
}

.maison_founder {
    padding: clamp(50px, 7vw, 98px) 20px;
    background: #fff;
}

.maison_founder_frame {
    display: grid;
    grid-template-columns: minmax(360px, 1.08fr) minmax(0, .92fr);
    gap: clamp(28px, 4.4vw, 64px);
    align-items: center;
    width: min(1240px, 100%);
    margin: 0 auto;
    padding: clamp(18px, 3.4vw, 42px);
    border: 1px solid rgba(6, 31, 95, .1);
    border-radius: 28px;
    background: #fff;
    box-shadow: 0 24px 70px rgba(16, 25, 54, .07);
}

.maison_founder_photo {
    min-height: 620px;
    margin: 0;
    border-radius: 26px;
    overflow: hidden;
    background: #efe7dc;
    box-shadow: 0 20px 54px rgba(16, 25, 54, .14);
}

.maison_founder_photo img {
    display: block;
    width: 100%;
    height: 100%;
    min-height: inherit;
    object-fit: cover;
}

.maison_founder_placeholder {
    display: grid;
    place-items: center;
    min-height: inherit;
    padding: 40px;
}

.maison_founder_placeholder img {
    width: min(210px, 55%);
    opacity: .28;
}

.maison_founder_content h2 {
    margin: 0 0 22px;
    color: #050b1b;
    font-family: Georgia, "Times New Roman", serif;
    font-size: clamp(2rem, 3.25vw, 3.45rem);
    font-weight: 400;
    line-height: .98;
    letter-spacing: 0;
}

.maison_founder_card {
    max-width: 680px;
    padding: clamp(22px, 2.6vw, 32px);
    border: 1px solid rgba(6, 31, 95, .09);
    border-radius: 26px;
    background: rgba(255, 250, 244, .92);
    box-shadow: 0 18px 48px rgba(16, 25, 54, .08);
}

.maison_founder_card p {
    margin: 0;
    color: #111827;
    font-size: .98rem;
    font-weight: 700;
    line-height: 1.65;
}

.maison_founder_card ul {
    display: grid;
    gap: 14px;
    margin: 22px 0 0;
    padding: 0;
    list-style: none;
}

.maison_founder_card li {
    position: relative;
    min-height: 30px;
    padding-left: 42px;
    color: #111827;
    font-size: .96rem;
    font-weight: 700;
    line-height: 1.55;
}

.maison_founder_card li::before {
    content: "✓";
    position: absolute;
    top: 1px;
    left: 0;
    display: grid;
    place-items: center;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: linear-gradient(135deg, #e8c65d, var(--maison-gold));
    color: #1f2937;
    font-size: .82rem;
    font-weight: 900;
    box-shadow: 0 8px 18px rgba(200, 155, 97, .28);
}

@media (max-width: 900px) {
    .maison_header {
        position: absolute;
    }

    .maison_hero {
        min-height: 100vh;
        padding: 118px 24px 58px;
    }

    .maison_hero_text {
        max-width: none;
    }

    .maison_hero_media {
        min-height: 100%;
    }

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

    .maison_founder_photo {
        min-height: 520px;
    }
}

@media (max-width: 560px) {
    .maison_header {
        padding: 18px 16px 0;
    }

    .maison_header_content {
        align-items: flex-start;
    }

    .maison_brand img {
        width: 36px;
        height: 36px;
    }

    .maison_login {
        min-height: 38px;
        padding: 9px 14px;
        font-size: .9rem;
    }

    .maison_hero {
        min-height: 100svh;
        padding: 110px 18px 42px;
    }

    .maison_hero h1 {
        font-size: clamp(2.35rem, 13vw, 3.5rem);
    }

    .maison_hero_media {
        min-height: 100%;
    }

    .maison_hero_media::after {
        background:
            linear-gradient(90deg, rgba(8, 8, 16, .86) 0%, rgba(20, 10, 24, .68) 70%, rgba(0, 0, 0, .22) 100%),
            linear-gradient(0deg, rgba(0, 0, 0, .42), transparent 45%);
    }

    .maison_hero_media img {
        object-position: 54% center;
    }

    .maison_founder {
        padding: 34px 14px;
    }

    .maison_founder_frame {
        padding: 16px;
        border-radius: 24px;
    }

    .maison_founder_photo {
        min-height: 420px;
        border-radius: 20px;
    }

    .maison_founder_card {
        padding: 20px;
        border-radius: 20px;
    }

    .maison_founder_card li {
        padding-left: 36px;
    }
}
