/* Lingua — доп. стили разговорного режима (поверх styles.css дизайн-системы). */

/* ── Кнопка озвучки (TTS) ── */
.speak-btn {
    display: inline-flex; align-items: center; justify-content: center;
    width: 30px; height: 30px; flex: 0 0 auto;
    border: 1px solid var(--border); border-radius: var(--r-pill);
    background: var(--surface); color: var(--c-secondary); cursor: pointer; padding: 0;
}
.speak-btn:hover { border-color: var(--c-secondary); background: var(--c-secondary-soft); }
.speak-btn svg { width: 16px; height: 16px; }
.speak-btn.is-speaking { color: var(--c-primary); border-color: var(--c-primary); background: var(--c-primary-soft); }

/* ── Темы (список сценариев) ── */
.topic-group { margin-bottom: 30px; }
.topic-group__head { display: flex; align-items: center; gap: 12px; margin: 0 0 14px; }
.topic-group__icon {
    width: 44px; height: 44px; flex: 0 0 auto; display: grid; place-items: center;
    font-size: 24px; background: var(--c-primary-soft); border-radius: var(--r-md);
}
.topic-group__title { margin: 0; font-size: 20px; }
.topic-group__count { color: var(--text-muted); font-size: 13px; margin-left: auto; }

.scenario-list { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
.scenario-card {
    display: flex; align-items: flex-start; gap: 12px; padding: 16px 18px;
    background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg);
    box-shadow: var(--sh-sm); color: var(--text);
}
.scenario-card:hover { text-decoration: none; border-color: var(--c-primary); box-shadow: var(--sh-md); }
.scenario-card__check {
    width: 26px; height: 26px; flex: 0 0 auto; display: grid; place-items: center;
    border-radius: var(--r-pill); border: 2px solid var(--border); color: var(--text-faint); font-size: 14px;
}
.scenario-card.is-done .scenario-card__check { background: var(--c-success); border-color: var(--c-success); color: #fff; }
.scenario-card__title { font-weight: 700; display: block; }
.scenario-card__goal { color: var(--text-muted); font-size: 13.5px; margin-top: 2px; display: block; }

/* ── Сценарий: диалог ── */
.scenario-toolbar { display: flex; gap: 10px; align-items: center; margin: 0 0 18px; flex-wrap: wrap; }
.scenario-toolbar .muted { font-size: 14px; }

.dialogue { display: flex; flex-direction: column; gap: 12px; margin: 8px 0 6px; }
.dline { display: flex; gap: 10px; max-width: 88%; }
.dline--you { align-self: flex-end; flex-direction: row-reverse; }
.dline__avatar {
    width: 34px; height: 34px; flex: 0 0 auto; border-radius: var(--r-pill);
    display: grid; place-items: center; font-size: 15px; font-weight: 800;
    background: var(--surface-2); color: var(--text-muted);
}
.dline--you .dline__avatar { background: var(--c-primary); color: #fff; }
.bubble {
    background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg);
    padding: 11px 14px; box-shadow: var(--sh-sm);
}
.dline--you .bubble { background: var(--c-primary-soft); border-color: transparent; }
.bubble__top { display: flex; align-items: center; gap: 8px; }
.bubble__es { font-size: 16.5px; font-weight: 600; }
.bubble__es .es { color: var(--c-primary-700); }
[data-theme="dark"] .bubble__es .es { color: #F4A06A; }
.bubble__ru { color: var(--text-muted); font-size: 14px; margin-top: 3px; }
.bubble__ru.is-hidden { filter: blur(5px); cursor: pointer; user-select: none; }
.bubble__note { color: var(--c-secondary); font-size: 12.5px; margin-top: 4px; }

/* ── Сценарий: ключевые фразы ── */
.phrases { display: flex; flex-direction: column; gap: 10px; margin-top: 6px; }
.phrase {
    display: flex; align-items: center; gap: 12px; padding: 12px 14px;
    background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md);
}
.phrase__body { flex: 1; }
.phrase__es { font-weight: 700; }
.phrase__es .es { color: var(--c-primary-700); }
[data-theme="dark"] .phrase__es .es { color: #F4A06A; }
.phrase__ru { color: var(--text-muted); font-size: 14px; }
.phrases-note { color: var(--text-muted); font-size: 13px; margin: 4px 0 0; }

.section-label {
    display: inline-flex; align-items: center; gap: 8px; font-weight: 800;
    font-size: 13px; text-transform: uppercase; letter-spacing: .04em;
    color: var(--c-secondary); margin: 26px 0 10px;
}
.section-label svg { width: 18px; height: 18px; }

/* флешкарта: кнопка озвучки в углу */
.flashcard__speak { position: absolute; top: 16px; right: 16px; }

@media (max-width: 640px) {
    .scenario-list { grid-template-columns: 1fr; }
    .dline { max-width: 100%; }
    /* 4 пункта таб-бара на узких экранах */
    .tabbar a { font-size: 10.5px; }
    .tabbar a svg { width: 21px; height: 21px; }
}
