/* learn-client: каталог курсов + прогрессивное открытие — дополнение к style.css/learn.css плеера */

/* вход: поле кода */
.code-input { text-align: center; letter-spacing: .5em; font-size: 22px; font-family: ui-monospace, monospace; }

/* ---- каталог курсов ---- */
.wrap { max-width: 900px; margin: 0 auto; padding: 26px 18px 60px; }
.top { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 20px; }
.top h1 { font-size: 24px; font-weight: 800; margin: 0; }
.who { color: var(--muted); font-size: 14px; white-space: nowrap; }
.who a { color: var(--accent); cursor: pointer; }
.grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); gap: 16px; }
.ccard { background: var(--panel); border: 1px solid var(--line); border-radius: 14px; padding: 18px; cursor: pointer; transition: .15s; }
.ccard:hover { border-color: var(--accent); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,0,0,.06); }
.ccard h3 { font-size: 17px; margin: 0 0 8px; }
.cmeta { color: var(--muted); font-size: 13px; margin-bottom: 10px; }
.cat { display: inline-block; background: #e7eefc; color: var(--accent-d); border-radius: 6px; padding: 1px 8px; margin-right: 6px; }
.ctags { display: flex; flex-wrap: wrap; gap: 6px; }
.ctags span { font-size: 11px; color: var(--muted); border: 1px solid var(--line); border-radius: 999px; padding: 2px 9px; }
.cprog { height: 5px; background: var(--line); border-radius: 4px; margin-top: 12px; overflow: hidden; }
.cprog-fill { height: 100%; background: var(--ok); border-radius: 4px; }
html[data-theme=night] .cat { background: #1a2740; }

/* ---- прогрессивное открытие ---- */
.pnav.locked { color: var(--muted); opacity: .55; cursor: not-allowed; }
.pnav.locked .chk { color: var(--muted); }
.block-advance { margin-top: 24px; display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.block-advance .primary { padding: 11px 22px; font-size: 15px; }
.hint { color: var(--muted); font-size: 13px; }

/* нижний дубль прогресс-бара */
.pprogress-bottom { margin-top: 26px; padding-top: 18px; border-top: 1px solid var(--line); display: flex; align-items: center; gap: 12px; }
.pprogress-bottom .prog-bar { flex: 1; height: 8px; background: var(--line); border-radius: 5px; overflow: hidden; }
.pprogress-bottom .prog-fill { height: 100%; background: var(--ok); border-radius: 5px; transition: width .4s ease; }
.pprogress-bottom .muted { white-space: nowrap; }
