/* Agenda */
.agenda {
    max-width: var(--container-max);
    margin-inline: auto;
    padding-inline: calc(var(--gap) * 2);
}

.agenda__content {
    display: flex;
    flex-direction: column;
}

.agenda__section-title {
    font-size: var(--text-md);
    font-weight: 700;
    line-height: 1.2;
    margin-block-end: calc(var(--gap) * 2);
}

.agenda__placeholder {
    text-align: center;
    color: var(--color-gray);
    padding-block: calc(var(--gap) * 4);
}

/* Moderator Box */
.agenda__moderator {
    background-color: #c3dfe9;
    border-radius: var(--radius-md);
    padding: calc(var(--gap) * 2);
    margin-block-end: calc(var(--gap) * 2);
}

.agenda__moderator-content {
    display: flex;
    align-items: center;
    gap: calc(var(--gap) * 2);
    flex-wrap: wrap;
    margin-inline: auto;

    @media (min-width: 1000px) {
        gap: calc(var(--gap) * 4);
        max-width: calc(100% - 200px);
    }
}

.agenda__moderator-image {
    width: 80px;
    height: 80px;
    border-radius: 50% !important;
    object-fit: cover;
    flex-shrink: 0;
}

.agenda__moderator-text {
    flex: 1;
    min-width: 200px;
}

.agenda__moderator-text p {
    margin: 0;
    font-size: var(--font-size-100);
    line-height: 1.5;
    color: var(--color-gray-dark);
}

.agenda__moderator-badge {
    color: #53606c;
    font-size: var(--text-xxs);
    font-weight: 600;
    letter-spacing: 0.05em;
    padding: calc(var(--gap) * 0.5) calc(var(--gap) * 1.5);
    border-radius: 9999px;
    text-transform: uppercase;
    flex-shrink: 0;
    border: 1px solid var(--color-gray);
}

@media (min-width: 1000px) {
    .agenda__moderator-content {
        flex-wrap: nowrap;
    }
}

/* Sessions */
.agenda__sessions {
    display: flex;
    flex-direction: column;
    gap: calc(var(--gap) * 2);
    list-style: none;
    padding: 0;
    margin: 0;
}

.agenda__session {
    display: flex;
    gap: calc(var(--gap) * 2);
    background-color: var(--color-gray-lightest);
    border-radius: var(--radius-md);
    padding: calc(var(--gap) * 2);
    flex-wrap: wrap;
    will-change: opacity, transform;

    @media (min-width: 1200px) {
        padding: calc(var(--gap) * 3);
    }
}

.section--gray-lightest .agenda__session,
.section--blue-ice .agenda__session,
.section--blue-navy .agenda__session,
.section--blue-navy-dark .agenda__session {
    background-color: var(--color-white);
}

@media (prefers-reduced-motion: reduce) {
    .agenda__session {
        opacity: 1 !important;
        transform: translateY(0) !important;
        will-change: auto;
    }
}

.agenda__session article {
    display: flex;
    gap: calc(var(--gap) * 2);
    flex-wrap: wrap;
    width: 100%;
}

.agenda__session--break {
    background-color: transparent !important;
    border: 1px solid hsl(from var(--color-gray) h s l / 0.5);
}

.section--blue-navy .agenda__session--break,
.section--blue-navy-dark .agenda__session--break {
    border-color: hsl(from var(--color-white) h s l / 0.5);
}

.agenda__session-time {
    font-size: var(--text-xs);
    font-weight: 400;
    flex-shrink: 0;
    min-width: 60px;
    display: block;
    color: var(--color-gray);
}

.section--blue-navy .agenda__session--break .agenda__session-time,
.section--blue-navy-dark .agenda__session--break .agenda__session-time {
    color: hsl(from var(--color-white) h s l / 0.8);
}

.agenda__session-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: calc(var(--gap) * 2);
}

.agenda__session-content:has(.agenda__session-speakers) {
    @media (min-width: 1200px) {
        flex-direction: row;
        gap: calc(var(--gap) * 8);
    }
}

.agenda__session-content>* {
    @media (min-width: 1200px) {
        flex: 1;
    }
}

.agenda__session-title {
    font-size: var(--text-xs);
    font-weight: 700;
    line-height: 1.4;
    color: var(--color-gray);
    margin: 0;
}

.section--blue-navy .agenda__session--break .agenda__session-title,
.section--blue-navy-dark .agenda__session--break .agenda__session-title {
    color: hsl(from var(--color-white) h s l / 0.8);
}

.agenda__session-speakers {
    display: flex;
    flex-direction: column;
    gap: calc(var(--gap) * 1.5);
    list-style: none;
    padding: 0;
    margin: 0;

    @media (min-width: 1200px) {
        min-width: 65%;
    }
}

.agenda__speaker {
    display: flex;
    align-items: center;
    gap: calc(var(--gap) * 1.5);
    list-style: none;
}

.agenda__speaker-image {
    width: 60px;
    height: 60px;
    border-radius: 50% !important;
    object-fit: cover;
    flex-shrink: 0;

    @media (min-width: 1200px) {
        width: 96px;
        height: 96px;
        margin-block: -18px;
    }
}

.agenda__speaker-info {
    flex: 1;
}

.agenda__speaker-name {
    font-size: var(--font-size-100);
    font-weight: 600;
    color: var(--color-gray);
    margin: 0 0 calc(var(--gap) * 0.25) 0;
    line-height: 1.3;
}

.agenda__speaker-title {
    font-size: var(--font-size-100);
    color: var(--color-gray);
    margin: 0;
    line-height: 1.4;
}

.agenda__session-description {
    flex: 1;
    color: var(--color-gray);
}

.agenda__session-image {
    flex-basis: 100%;
    width: 100%;
}

.agenda__session-image img {
    object-fit: cover;
    border-radius: var(--radius-md);
    width: 100%;
}

@media (min-width: 768px) {
    .agenda__session-time {
        min-width: 80px;
    }

    .agenda__session-speakers {
        flex-direction: row;
        flex-wrap: wrap;
    }
}

.agenda__session-info {
    display: flex;
    flex-direction: column;
    gap: calc(var(--gap) * 1.5);
    padding-block: calc(var(--gap) * 2);
    color: var(--color-gray);
}

.agenda__session-info-label {
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: var(--text-xxs);
    font-weight: 500;
    color: var(--color-blue-sky);
    margin: 0;
}

.agenda__session-info-list {
    display: flex;
    flex-direction: column;
    gap: calc(var(--gap) * 1.5);
    padding: 0;
    margin: 0;
}

.agenda__session-info-item {
    list-style: none;
}

.agenda__session-info-name {
    margin: 0 0 calc(var(--gap) * 0.25) 0;
    font-weight: 700;
    font-size: var(--text-xxs);
    color: var(--color-gray);
}