/* ============================================================
   M0 — модалка «Новое событие» (Занятие | Личное).
   Порт дизайн-эталона design_handoff_update/lesson-modal.jsx → LessonModalM0.

   Скоуп: всё под .m0-overlay. Дизайн-токены хэндоффа (--ink-*, --hairline,
   --indigo, --lavender-*) мапим на переменные нашей светлой темы, чтобы
   не плодить вторую палитру.
   ============================================================ */

.m0-overlay {
    /* алиасы токенов хэндоффа → наша тема */
    --ink-1: var(--text, #2A2622);
    --ink-2: var(--text-secondary, #595048);
    --ink-3: var(--text-dim, #8A7F73);
    --ink-4: var(--text-faint, #B8AE9F);
    --hairline: var(--border, #EAE3D5);
    --hairline-strong: var(--border-strong, #D9D0BC);
    --surface: var(--bg-card, #FFFFFF);
    --surface-2: var(--bg-card-2, #FBF8F2);
    --indigo: var(--brand, #3D3A8E);
    --indigo-2: var(--brand-hover, #5754AE);

    position: fixed; inset: 0;
    background: rgba(20, 16, 12, 0.5);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    display: flex; align-items: center; justify-content: center;
    z-index: 9500;
    padding: 20px;
    animation: anim-fade-in 0.18s ease-out both;
}
.m0-overlay[hidden] { display: none !important; }
/* Критично: эталон скоупит box-sizing на все потомки (.tk *). Без этого
   border на заглушке-аватаре ломает flex-расчёты → овал вместо круга. */
.m0-overlay * { box-sizing: border-box; }

.m0-card {
    width: 100%; max-width: 480px;
    background: var(--surface);
    border-radius: 16px;
    box-shadow: var(--shadow-3, 0 18px 40px rgba(60,50,40,.10), 0 6px 14px rgba(60,50,40,.06));
    animation: m0-modal-in .28s cubic-bezier(.2,.8,.3,1);
    max-height: calc(100vh - 40px);
    display: flex; flex-direction: column;
}
@keyframes m0-modal-in {
    from { opacity: 0; transform: translateY(14px) scale(.96); }
    to   { opacity: 1; transform: none; }
}
@keyframes m0-pop {
    from { opacity: 0; transform: translateY(-6px) scale(.97); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes m0-fade-up {
    from { opacity: 0; transform: translateY(6px); }
    to   { opacity: 1; transform: none; }
}
@keyframes m0-swap-in {
    /* мягче: лёгкий лифт + fade вместо резкого сдвига вбок */
    from { opacity: 0; transform: translateY(4px); }
    to   { opacity: 1; transform: none; }
}
.m0-dd-pop  { animation: m0-pop .16s cubic-bezier(.2,.8,.3,1); transform-origin: top center; }
.m0-fade-up { animation: m0-fade-up .26s cubic-bezier(.22,1,.36,1); }
.m0-swap-in { animation: m0-swap-in .28s cubic-bezier(.22,1,.36,1); }

@media (prefers-reduced-motion: reduce) {
    .m0-overlay, .m0-overlay * { animation: none !important; transition: none !important; }
}

/* ── Header ── */
.m0-head {
    padding: 18px 24px 0;
    display: flex; align-items: flex-start; gap: 12px;
}
.m0-title {
    margin: 0; flex: 1;
    font-size: 18px; font-weight: 600;
    letter-spacing: -0.01em;
    color: var(--ink-1);
}
.m0-close {
    background: transparent; border: none; cursor: pointer;
    color: var(--ink-3); padding: 4px;
    margin: -2px -6px 0 0;
    border-radius: 6px;
    font-size: 16px; line-height: 1;
    transition: color .15s, background .15s;
}
.m0-close:hover { color: var(--ink-1); background: var(--bg-soft); }

/* ── Tabs ── */
.m0-tabs {
    display: flex; gap: 20px;
    padding: 0 24px;
    border-bottom: 1px solid var(--hairline);
    margin-top: 8px;
}
.m0-tab {
    background: transparent; border: none; cursor: pointer;
    font-family: inherit; font-size: 13.5px; font-weight: 600;
    color: var(--ink-3);
    padding: 10px 2px 9px;
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    transition: color .15s;
}
.m0-tab.active {
    color: var(--ink-1);
    border-bottom-color: var(--indigo);
}

/* ── Body ── */
.m0-body {
    padding: 18px 24px;
    display: flex; flex-direction: column; gap: 14px;
    overflow-y: auto;
}
.m0-field { display: flex; flex-direction: column; gap: 6px; }
.m0-label {
    font-size: 11px; letter-spacing: .08em; text-transform: uppercase;
    color: var(--ink-3); font-weight: 600;
    display: flex; align-items: baseline; gap: 6px;
}
.m0-label .req { color: var(--rose, #C75A6E); }
.m0-label .hint { font-weight: 500; text-transform: none; letter-spacing: 0; color: var(--ink-4); font-size: 11px; }

.m0-row-3 {
    display: grid;
    grid-template-columns: 1.2fr 1fr 1fr;
    gap: 10px;
}

/* Инпуты */
.m0-input, .m0-textarea, .m0-select-btn {
    width: 100%; box-sizing: border-box;
    padding: 8px 12px;
    font-size: 13px; font-family: inherit;
    background: var(--surface); color: var(--ink-1);
    border: 1px solid var(--hairline);
    border-radius: 8px;
    outline: none;
    transition: border-color .15s, box-shadow .15s;
}
.m0-input:focus, .m0-textarea:focus {
    border-color: var(--ink-3);
    box-shadow: 0 0 0 3px rgba(61, 58, 142, .10);
}
.m0-textarea { resize: vertical; min-height: 54px; }

/* ── KindToggle (Ученик / Группа) ── */
.m0-kind {
    display: grid; grid-template-columns: 1fr 1fr; gap: 4px;
    padding: 3px;
    background: var(--bg-soft);
    border: 1px solid var(--hairline);
    border-radius: 10px;
}
.m0-kind button {
    border: none; background: transparent;
    color: var(--ink-3);
    font-size: 13px; font-weight: 600; font-family: inherit;
    padding: 7px 12px; border-radius: 7px; cursor: pointer;
    display: inline-flex; align-items: center; gap: 8px; justify-content: center;
    transition: background .15s, color .15s, box-shadow .15s;
}
.m0-kind button.active {
    background: var(--surface);
    color: var(--ink-1);
    box-shadow: var(--shadow-1, 0 1px 2px rgba(60,50,40,.04));
}
.m0-kind button .ico { display: inline-flex; color: var(--ink-4); }
.m0-kind button.active .ico { color: var(--lavender-ink, #4A4790); }

/* ── StudentPicker / GroupPicker ── */
.m0-picker { position: relative; }
.m0-picker-row {
    width: 100%; box-sizing: border-box;
    padding: 5px 5px 5px 10px;
    font-size: 13px;
    background: var(--surface); color: var(--ink-1);
    border: 1px solid var(--hairline);
    border-radius: 8px;
    display: flex; align-items: center; gap: 8px;
    min-height: 38px;                 /* как в эталоне — без фикс. height */
    transition: border-color .15s;
}
.m0-picker-row.open { border-color: var(--ink-3); }
.m0-picker-main {
    display: flex; align-items: center; gap: 10px;
    background: transparent; border: none; padding: 0; margin: 0;
    cursor: pointer; font-family: inherit; color: inherit;
    flex: 1; min-width: 0; text-align: left;
    font-size: 13px;
}
.m0-picker-main .name {
    font-weight: 500; color: var(--ink-1);
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.m0-picker-main .placeholder { color: var(--ink-3); }
.m0-av {
    /* Жёсткая фиксация по ОБЕИМ осям: min/max + flex:none + align-self:center.
       Без этого flex-basis/aspect-ratio дрались и аватар растягивался в овал. */
    width: 26px; height: 26px;
    min-width: 26px; max-width: 26px;
    min-height: 26px; max-height: 26px;
    flex: none; align-self: center;
    border-radius: 999px;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 11px; font-weight: 700;
    background: var(--lavender-soft, #E5E2F8); color: var(--lavender-ink, #4A4790);
}
/* is-empty (НЕ "empty" — глобальный .empty в teacher.css даёт padding 48px!) */
.m0-av.is-empty {
    background: var(--bg-soft);
    border: 1px dashed var(--hairline-strong);
}
.m0-chev {
    background: transparent; border: none; padding: 4px; cursor: pointer;
    color: var(--ink-3); display: inline-flex; flex: none;
    transition: transform .18s ease;
}
.m0-chev.open { transform: rotate(180deg); }

/* Чип предмета в строке выбранного ученика */
.m0-subj-wrap { position: relative; flex: none; }
.m0-subj-chip {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 4px 10px;
    border-radius: 999px;
    background: var(--lavender-soft, #E5E2F8);
    color: var(--lavender-ink, #4A4790);
    border: 1px solid transparent;
    font-size: 12px; font-weight: 600; font-family: inherit;
    cursor: default; line-height: 1.1;
}
.m0-subj-chip.multi { cursor: pointer; padding-right: 6px; }
.m0-subj-chip.open { border-color: var(--lavender-ink, #4A4790); }
.m0-subj-chip .m0-chev { padding: 0; color: var(--lavender-ink, #4A4790); opacity: .7; }

/* Дропдауны */
.m0-dd {
    position: absolute; top: calc(100% + 4px); left: 0; right: 0; z-index: 20;
    background: var(--surface); border: 1px solid var(--hairline);
    border-radius: 10px;
    box-shadow: 0 12px 32px rgba(0,0,0,.12), 0 2px 6px rgba(0,0,0,.04);
    overflow: hidden;
}
.m0-dd.narrow { left: auto; right: 0; min-width: 140px; }
.m0-dd-search {
    display: flex; align-items: center; gap: 8px;
    padding: 9px 12px;
    border-bottom: 1px solid var(--hairline);
}
.m0-dd-search input {
    flex: 1; border: none; outline: none; background: transparent;
    font-size: 13px; font-family: inherit; color: var(--ink-1); padding: 0;
    box-shadow: none !important;
}
.m0-dd-search .ico { color: var(--ink-3); flex: none; font-size: 13px; }
.m0-dd-search .clear {
    background: transparent; border: none; cursor: pointer;
    color: var(--ink-4); padding: 2px; display: inline-flex; font-size: 12px;
}
.m0-dd-list { padding: 4px; max-height: 240px; overflow: auto; }
.m0-dd-item {
    width: 100%; text-align: left; border: none;
    background: transparent;
    color: var(--ink-1); font-family: inherit;
    padding: 7px 8px; border-radius: 7px; cursor: pointer;
    display: flex; align-items: center; gap: 10px;
    font-size: 13px; font-weight: 500;
    transition: background .1s;
}
.m0-dd-item:hover { background: var(--bg-soft); }
.m0-dd-item.active { background: var(--lavender-soft, #E5E2F8); }
.m0-dd-item .grow { flex: 1; min-width: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.m0-dd-item .meta { font-size: 11.5px; color: var(--ink-3); flex: none; }
.m0-dd-item .check { color: var(--lavender-ink, #4A4790); flex: none; font-size: 13px; }
.m0-dd-empty {
    padding: 16px 10px; text-align: center;
    font-size: 12.5px; color: var(--ink-3);
}

/* ── EmojiPicker ── */
.m0-emoji-wrap { position: relative; flex: none; }
.m0-emoji-btn {
    width: 36px; height: 36px; box-sizing: border-box;
    background: var(--surface);
    border: 1px solid var(--hairline);
    border-radius: 8px; cursor: pointer;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 17px; font-family: inherit; color: var(--ink-4);
    transition: border-color .15s;
}
.m0-emoji-btn.open { border-color: var(--ink-3); }
.m0-emoji-dd {
    position: absolute; top: calc(100% + 4px); left: 0; z-index: 30;
    background: var(--surface); border: 1px solid var(--hairline);
    border-radius: 10px;
    box-shadow: 0 12px 32px rgba(0,0,0,.12), 0 2px 6px rgba(0,0,0,.04);
    padding: 8px; width: 260px;
}
/* Иконка через CSS-маску (красится currentColor) */
.evt-ico {
    display: inline-block; flex: none;
    background-color: currentColor;
    vertical-align: -2px;
}
/* Пикер иконок: группы + сетка 5 колонок, скролл */
.m0-ico-scroll { max-height: 280px; overflow-y: auto; }
.m0-ico-group-cap {
    font-size: 11px; font-weight: 600; letter-spacing: .06em;
    text-transform: uppercase; color: var(--ink-3);
    padding: 6px 4px 4px;
}
.m0-ico-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 2px; }
.m0-ico-cell {
    border: 1px solid transparent; border-radius: 8px; cursor: pointer;
    background: transparent; padding: 6px 0; font-family: inherit;
    display: inline-flex; align-items: center; justify-content: center;
    transition: background .1s, border-color .1s;
}
.m0-ico-cell:hover { background: var(--bg-soft); }
.m0-ico-cell.active {
    background: var(--brand-bg, var(--lavender-soft, #E5E2F8));
    border-color: var(--brand, #3D3A8E);
}
.m0-emoji-none {
    width: 100%; margin-top: 6px;
    background: transparent; border: none;
    border-top: 1px solid var(--hairline);
    cursor: pointer; font-family: inherit;
    font-size: 12px; font-weight: 600; color: var(--ink-3);
    padding: 8px 0 4px;
}

/* ── Карточка просмотра личного (P1): плашка-иконка + бейдж «Личное» ── */
.m0-pc-accent {
    width: 44px; height: 44px; flex: none;
    border-radius: 12px;
    background-color: var(--bg-soft, #F4EFE5);
    background-image: repeating-linear-gradient(135deg,
        rgba(138,127,115,.06) 0 6px, transparent 6px 12px);
    border: 1px solid var(--hairline-strong, #D9D0BC);
    display: inline-flex; align-items: center; justify-content: center;
    color: var(--ink-2, #595048);
}
.m0-pc-badge {
    display: inline-block;
    font-size: 10.5px; font-weight: 600; letter-spacing: .04em;
    text-transform: uppercase; color: var(--ink-3, #8A7F73);
}
.m0-pc-date { font-size: 12.5px; color: var(--ink-3, #8A7F73); margin-top: 3px; }

/* InfoRow в карточке просмотра личного (P1) */
.m0-inforow {
    display: flex; align-items: flex-start; gap: 12px;
    padding: 4px 0;
}
.m0-inforow-ico {
    flex: none; width: 28px; height: 28px; margin-top: 1px;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 8px; background: var(--bg-soft, #F4EFE5);
    color: var(--ink-3, #8A7F73);
}
.m0-inforow-v { font-size: 14px; color: var(--ink-1, #2A2622); font-weight: 500; }
.m0-inforow-sub { font-size: 12.5px; color: var(--ink-3, #8A7F73); margin-top: 1px; }
.m0-next-day {
    display: inline-block; margin-left: 4px;
    font-size: 10.5px; font-weight: 600;
    padding: 1px 6px; border-radius: 999px;
    background: var(--amber-soft, #F8EBC5); color: var(--amber-ink, #7A5D14);
}

/* Карточка заметки */
.m0-note-card {
    background: var(--surface-2, #FBF8F2);
    border: 1px solid var(--hairline, #EAE3D5);
    border-radius: 10px; padding: 10px 12px;
}
.m0-note-text {
    font-size: 13px; color: var(--ink-2, #595048); line-height: 1.5;
    margin-top: 4px; white-space: pre-wrap;
}

/* ── Палитра цвета метки личного события ── */
.m0-colors { display: flex; gap: 8px; flex-wrap: wrap; }
.m0-color-sw {
    width: 26px; height: 26px; border-radius: 7px;
    border: 2px solid transparent; cursor: pointer; padding: 0;
    background: var(--sw, #ccc);
    position: relative;
    transition: transform .1s, box-shadow .15s;
}
.m0-color-sw:hover { transform: scale(1.08); }
.m0-color-sw.active {
    border-color: var(--surface);
    box-shadow: 0 0 0 2px var(--sw, var(--ink-3));
}
.m0-color-none {
    background:
        linear-gradient(135deg, transparent 45%, var(--rose, #C75A6E) 45%, var(--rose, #C75A6E) 55%, transparent 55%),
        var(--bg-soft, #F4EFE5);
    --sw: var(--ink-3, #8A7F73);
}
.m0-color-none.active { box-shadow: 0 0 0 2px var(--ink-3, #8A7F73); }

/* ── Подпись «Окончание»: время конца + длительность подсказкой ── */
.m0-end-dur { color: var(--ink-3, #8A7F73); font-weight: 400; }

/* Дропдаун окончаний — прокручиваемый, шаг 15 мин */
.m0-end-list { max-height: 240px; overflow-y: auto; }
.m0-end-opt {
    display: flex; align-items: center; gap: 10px;
    justify-content: flex-start;
    font-variant-numeric: tabular-nums;
}
.m0-end-time { flex: none; min-width: 64px; }
.m0-end-len { flex: 1; color: var(--ink-3, #8A7F73); font-size: 12px; font-weight: 400; }
.m0-end-opt .check { flex: none; }

/* Тонкий видимый скроллбар */
.scroll-y { scrollbar-width: thin; scrollbar-color: var(--hairline-strong, #D9D0BC) transparent; }
.scroll-y::-webkit-scrollbar { width: 7px; }
.scroll-y::-webkit-scrollbar-thumb { background: var(--hairline-strong, #D9D0BC); border-radius: 4px; }
.scroll-y::-webkit-scrollbar-track { background: transparent; }

/* ── RepeatSelect ── */
.m0-repeat { display: flex; flex-direction: column; gap: 8px; }
.m0-repeat-sel { position: relative; }
.m0-dur-sel { position: relative; }
.m0-select-btn {
    cursor: pointer; text-align: left;
    display: flex; align-items: center; gap: 8px;
    padding: 8px 10px 8px 12px;
}
.m0-select-btn.open { border-color: var(--ink-3); }
.m0-select-btn .grow { flex: 1; }
.m0-select-btn .ico { flex: none; color: var(--ink-4); font-size: 13px; display: inline-flex; }
.m0-select-btn .ico.on { color: var(--lavender-ink, #4A4790); }
.m0-dd-opt {
    width: 100%; text-align: left; border: none;
    background: transparent; color: var(--ink-1);
    font-size: 13px; font-weight: 500; font-family: inherit;
    padding: 7px 10px; border-radius: 6px; cursor: pointer;
    display: flex; align-items: center; gap: 8px;
    transition: background .1s;
}
.m0-dd-opt:hover { background: var(--bg-soft); }
.m0-dd-opt.active {
    background: var(--lavender-soft, #E5E2F8);
    color: var(--lavender-ink, #4A4790);
    font-weight: 600;
}
.m0-dd-opt .grow { flex: 1; }
.m0-days { display: flex; gap: 4px; align-items: center; }
.m0-day {
    width: 32px; height: 28px; box-sizing: border-box;
    border: 1px solid var(--hairline);
    background: var(--surface);
    color: var(--ink-3);
    font-size: 11.5px; font-weight: 600; font-family: inherit;
    border-radius: 7px; cursor: pointer;
    transition: background .12s, border-color .12s, color .12s;
}
.m0-day.active {
    border-color: var(--lavender-ink, #4A4790);
    background: var(--lavender-soft, #E5E2F8);
    color: var(--lavender-ink, #4A4790);
}
.m0-days .note { font-size: 11px; color: var(--ink-4); margin-left: 6px; }

/* ── Info-строка для личного ── */
.m0-info {
    display: flex; align-items: center; gap: 8px;
    font-size: 11.5px; color: var(--ink-3);
    margin-top: -4px;
}

/* ── Footer ── */
.m0-foot {
    padding: 14px 24px;
    background: var(--surface-2);
    display: flex; gap: 8px; align-items: center;
    border-top: 1px solid var(--hairline);
    border-radius: 0 0 15px 15px;
}
.m0-btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 8px 14px; border-radius: 10px;
    font-size: 13px; font-weight: 600; font-family: inherit;
    border: 1px solid transparent;
    cursor: pointer;
    transition: background .15s, transform .1s, opacity .15s;
}
.m0-btn:active { transform: scale(.985); }
.m0-btn-ghost { background: transparent; color: var(--ink-2); }
.m0-btn-ghost:hover { background: var(--bg-soft); }
.m0-btn-primary {
    background: var(--indigo); color: #fff;
    border-color: var(--indigo);
    padding: 9px 18px;
}
.m0-btn-primary:hover { background: var(--indigo-2); }
.m0-btn-primary:disabled {
    opacity: .55; cursor: not-allowed;
    transform: none;
}
.m0-btn-danger {
    background: var(--rose, #C75A6E); color: #fff;
    border-color: var(--rose, #C75A6E);
    padding: 9px 18px;
}
.m0-btn-danger:hover { background: var(--rose-ink, #8E3A4A); }

/* ── Модалка подтверждения (m0Confirm) ── */
.m0-confirm-ov {
    /* алиасы токенов (модалка вне .m0-overlay, тянем из темы проекта) */
    --surface: var(--bg-card, #FFFFFF);
    --ink-1: var(--text, #2A2622);
    --ink-2: var(--text-secondary, #595048);
    --bg-soft: var(--bg-soft, #F4EFE5);
    --indigo: var(--brand, #3D3A8E);
    --indigo-2: var(--brand-hover, #5754AE);
    --rose: var(--red, #C75A6E);
    --rose-ink: var(--red-ink, #8E3A4A);

    position: fixed; inset: 0; z-index: 9700;
    background: rgba(20, 16, 12, 0.5);
    backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
    display: flex; align-items: center; justify-content: center;
    padding: 20px;
    animation: anim-fade-in 0.16s ease-out both;
}
.m0-confirm-ov * { box-sizing: border-box; }
.m0-confirm-card {
    width: 100%; max-width: 360px;
    background: var(--surface, #fff);
    border-radius: 14px;
    box-shadow: var(--shadow-3, 0 18px 40px rgba(60,50,40,.10), 0 6px 14px rgba(60,50,40,.06));
    padding: 22px 22px 16px;
    animation: m0-modal-in .24s cubic-bezier(.2,.8,.3,1);
}
.m0-confirm-msg {
    font-size: 15px; line-height: 1.5;
    color: var(--ink-1, #2A2622);
    margin-bottom: 18px;
}
.m0-confirm-foot {
    display: flex; gap: 10px; justify-content: flex-end;
}
