.ttm-intro .ttm-kicker {
    margin: 0 0 .4rem;
    text-transform: uppercase;
    letter-spacing: .12em;
    font-size: .78rem;
    font-weight: 700;
    color: #1e56d5;
}

.ttm-intro .ttm-title {
    margin: 0;
    font-weight: 800;
    color: #1c2f54;
}

.ttm-intro .ttm-subtext {
    margin: .7rem auto 0;
    max-width: 720px;
    color: #63759a;
}

.ttm-card {
    position: relative;
    border-radius: 18px;
    border: 1px solid #dce6f8;
    background: linear-gradient(180deg, #fff 0%, #f8fbff 100%);
    box-shadow: 0 12px 30px rgba(19, 41, 86, .08);
    padding: 22px;
    transition: transform .25s ease, box-shadow .25s ease;
}

.ttm-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 18px 38px rgba(19, 41, 86, .14);
}

.ttm-quote {
    color: #9eb6e7;
    font-size: 1.2rem;
    margin-bottom: .4rem;
}

.ttm-givenby {
    margin: 0 0 .75rem;
    color: #1f3562;
    font-size: 1rem;
    font-weight: 700;
}

.ttm-message {
    margin: 0;
    color: #324a79;
    font-size: .93rem;
    line-height: 1.8;
}

.ttm-meta {
    margin-top: 1rem;
    padding-top: .8rem;
    border-top: 1px dashed #d7e3fb;
    display: flex;
    justify-content: space-between;
    gap: 10px;
}

.ttm-relation {
    color: #4b6390;
    font-size: .8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
}

.ttm-student {
    color: #1f3562;
    font-size: .92rem;
    font-weight: 700;
}

.ttm-class-label {
    color: #4b6390;
    font-size: .75rem;
    text-transform: uppercase;
    font-weight: 700;
}

.ttm-class {
    color: #1f3562;
    font-size: .9rem;
    font-weight: 700;
}

.ttm-empty {
    border-radius: 16px;
    border: 1px dashed #cbd8f1;
    background: #f8fbff;
    padding: 42px 20px;
}

.ttm-empty i {
    font-size: 2.2rem;
    color: #8ca4d2;
    margin-bottom: 10px;
}

.ttm-empty h3 {
    margin: 0;
    font-size: 1.05rem;
    color: #2a406d;
}

.ttm-empty p {
    margin: .45rem 0 0;
    color: #5d7298;
}
