:root {
    --bg: #000;
    /* fond bleu du schéma */
    --black: #0b0b0d;
    --card: #111114;
    --muted: rgba(255, 255, 255, .72);
    --muted2: rgba(255, 255, 255, .55);

    --yellow: #111114;
    --pill: #e9eef3;

    --radius-xl: 30px;
    --radius-lg: 30px;
    --radius-md: 30px;

    --shadow: 0 18px 60px rgba(0, 0, 0, .35);
    --stroke: rgba(255, 255, 255, .10);
    --stroke2: rgba(255, 255, 255, .14);

    --font-main: 'Montserrat', sans-serif;

    --blue-btn: #2f66ff;
}

* {
    box-sizing: border-box;
}

html,
body {
    height: 100%;
}

body {
    margin: 0;
    font-family: var(--font-main);
    background: var(--bg) center / cover no-repeat fixed;
    color: #0b0b0d;
}

.wrap {
    width: min(420px, calc(100% - 28px));
    /* rendu mobile comme ton schéma */
    margin: 0 auto;
}

/* Header noir */
.topbar {
    background: #000;
    color: #fff;
    padding: 40px 0;
}

.topbar__inner {
    display: flex;
    justify-content: center;
    align-items: center;
}

.topbar__title {
    font-weight: 700;
    letter-spacing: .2px;
}

/* Page */
.page {
    padding: 18px 0 32px;
}

/* HERO (bloc jaune) */
.hero {
    padding: 26px 18px 22px;
    text-align: center;
    box-shadow: var(--shadow);
    border: 1px solid rgba(255, 255, 255, .08);
    background: linear-gradient(180deg, #0f1014, #0b0b0d);
}

.hero__t1 {
    margin: 0;
    font-size: 16px;
    font-weight: 800;
    margin-bottom: 30px;
    color: white;
}

.hero__t2 {
    margin: 14px 0 18px;
    font-size: 12px;
    font-weight: 300;
    color: white;
}

.btn {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    text-decoration: none;
    font-weight: 800;
    margin-top: 15px;
    border-radius: 100px;
    padding: 12px 16px;
}

.btn--hero {
    background: #ffffff;
    color: #000;
    border: 1px solid rgba(0, 0, 0, .12);
    width: 72%;
    max-width: 280px;
}

/* Bande membres noire */
.members {
    position: relative;
    padding: 12px 14px;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    box-shadow: var(--shadow);
    border: 1px solid rgba(255, 255, 255, .08);
    background: linear-gradient(180deg, #0f1014, #0b0b0d);
    /* IMPORTANT */
    overflow: hidden;
    /* IMPORTANT */
}


.members__avatars {
    display: flex;
    align-items: center;
    min-width: 160px;
}

.members__avatars img {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    object-fit: cover;
    margin-left: -10px;
    background: #fff;
}

.members__avatars img:first-child {
    margin-left: 0;
}



.members__right {
    text-align: right;
    line-height: 1.05;
}

.stars {
    color: #74ff9c;
    font-size: 14px;
    letter-spacing: 1px;
    font-weight: 900;
}

.members__count {
    margin-top: 6px;
    font-weight: 800;
    font-size: 13px;
    color: rgba(255, 255, 255, .85);
}

/* Carte vidéo + stats */
.media-card {
    overflow: hidden;
    box-shadow: var(--shadow);
    border: 1px solid rgba(255, 255, 255, .08);
    background: linear-gradient(180deg, #0f1014, #0b0b0d);
}

.media-card__video {
    height: auto;
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}

.media-card__video video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    /* remplit le bloc proprement */
}

.media-card__stats {
    display: grid;
    grid-template-columns: 1fr 10px 1fr;
    align-items: stretch;
    padding: 14px 14px 16px;
    color: #fff;
    background: linear-gradient(180deg, rgba(255, 255, 255, .06), rgba(255, 255, 255, .02));
}

.stat {
    text-align: center;
    padding: 8px 6px;
}

.stat__label {
    color: rgba(255, 255, 255, .62);
    font-weight: 700;
    font-size: 12px;
    line-height: 1.2;
}

.stat__value {
    margin-top: 10px;
    font-weight: 900;
    font-size: 22px;
}

.divider {
    width: 1px;
    background: rgba(255, 255, 255, .10);
    margin: 0 auto;
}

/* pill " Advantages" */
.pill-row {
    display: flex;
    justify-content: center;
    margin-top: 40px;
}

.pill {
    padding: 10px 16px;
    border-radius: 999px;
    background: rgb(255, 255, 255);
    color: #0b0b0d;
    font-weight: 800;
}

/* Textes milieu */
.texts {
    padding: 26px 6px 18px;
    text-align: center;
}

.text1 {
    margin: 18px 0 0;
    font-size: 22px;
    margin-bottom: 40px;
    font-weight: bold;
    color: white;
}

.texts__p {
    margin: 18px 0 0;
    font-size: 18px;
    font-weight: 300;
    color: white;
    margin-bottom: 50px;
}

/* Carte appel */
.call-card {
    margin-top: 24px;
    padding: 18px 16px 16px;
    color: #fff;
    box-shadow: var(--shadow);
    border: 1px solid rgba(255, 255, 255, .08);
    background: linear-gradient(180deg, #0f1014, #0b0b0d);
}


.call-card__title {
    margin: 1px 0 0;
    font-weight: 900;
    letter-spacing: -.4px;
    font-size: 22px;
    line-height: 1.15;
}

.call-card__title .icon {
    display: inline-block;
    transform: translateY(2px);
}

.call-card__desc {
    margin: 10px 0 0;
    color: rgba(255, 255, 255, .70);
    line-height: 1.55;
    font-weight: 600;
    font-size: 13px;
}

/* Inner card */
.inner-card {
    margin-top: 16px;
    border-radius: var(--radius-lg);
    padding: 14px;
    box-shadow: var(--shadow);
    border: 1px solid rgba(255, 255, 255, .08);
    background: linear-gradient(180deg, #0f1014, #0b0b0d);
}

.inner-card__who {
    display: flex;
    gap: 10px;
    align-items: center;
}

.mini-avatar {
    width: 34px;
    height: 34px;
    border-radius: 999px;

}

.mini-avatar img {
    width: 34px;
    height: 34px;
    border-radius: 999px;
}

.who__name {
    font-weight: 800;
    font-size: 12px;
    color: rgba(255, 255, 255, .65);
}

.who__role {
    margin-top: 2px;
    font-weight: 900;
    font-size: 14px;
}

.inner-card__desc {
    margin: 12px 0 0;
    color: rgba(255, 255, 255, .70);
    line-height: 1.5;
    font-weight: 600;
    font-size: 13px;
}

.btn--blue {
    width: 100%;
    margin-top: 12px;
    background: var(--blue-btn);
    color: #fff;
    border-radius: 100px;
    padding: 14px 16px;
}

.road {
    padding: 18px 16px 16px;
    color: #fff;
    box-shadow: var(--shadow);
    border: 1px solid rgba(255, 255, 255, .08);
    background: linear-gradient(180deg, #0f1014, #0a0a0a88);
}

/* Roadmap */
.roadmap {
    margin-top: 16px;
    text-align: center;
    padding: 10px 0 0;
}

.roadmap__title {
    font-weight: 900;
    font-size: 16px;
    margin-bottom: 8px;
    color: rgb(255, 255, 255);
}

.roadmap__year {
    font-weight: 900;
    font-size: 28px;
    margin-bottom: 20px;
    margin-top: 20px;
    padding: 14px 0;
    color: rgb(255, 255, 255);
}

.roadmap__desc {
    font-size: 14px;
    color: rgb(255, 255, 255);
    line-height: 1.5;
    max-width: 260px;
    margin: 0 auto;
    margin-bottom: 50px;

}