@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0d13;--sidebar: #0c1017;--surface: #10151e;--surface-hd: #0e131c;--modal-bg: #141a26;--border: rgba(255,255,255,.06);--border-row: rgba(255,255,255,.045);--border-ctrl: rgba(255,255,255,.1);--border-input: rgba(255,255,255,.12);--text: #e8eaef;--text-2: #c4cad6;--text-3: #9aa2b0;--muted: #7a8290;--dim: #5e6675;--faint: #454d5c;--accent: #5b8def;--accent-hover: #6f9bf5;--accent-soft: rgba(91,141,239,.13);--accent-glow: 0 1px 0 rgba(255,255,255,.18) inset, 0 6px 16px -6px rgba(91,141,239,.7);--good: #5fd39a;--warn: #e0a93b;--bad: #ef5a63;--bad-soft: rgba(239,90,99,.08);--bad-border: rgba(239,90,99,.32);font-family:IBM Plex Sans,-apple-system,BlinkMacSystemFont,sans-serif;font-size:13.5px;letter-spacing:.1px;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}body{min-height:100vh}::-webkit-scrollbar{width:11px;height:11px}::-webkit-scrollbar-thumb{background:#ffffff17;border-radius:8px;border:3px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:#ffffff29;background-clip:padding-box}::-webkit-scrollbar-track{background:transparent}input::placeholder{color:var(--faint)}@keyframes ris-fade{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes ris-pop{0%{opacity:0;transform:translateY(10px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}.app{display:flex;min-height:100vh}.sidebar{width:212px;flex-shrink:0;background:var(--sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.sidebar__brand{padding:22px 20px 18px;display:flex;align-items:center;gap:9px}.sidebar__brand-dot{width:9px;height:9px;border-radius:2px;background:var(--accent);box-shadow:0 0 0 3px #5b8def2e;flex-shrink:0}.sidebar__brand-name{font-weight:700;font-size:15px;letter-spacing:.2px;color:#cfe0ff}.sidenav{display:flex;flex-direction:column;gap:2px;padding:8px 12px}.sidenav__item{display:flex;align-items:center;gap:10px;padding:8px 12px;width:100%;text-align:left;color:var(--text-3);border-radius:8px;border:none;background:transparent;font:inherit;font-size:13px;font-weight:500;cursor:pointer;transition:background .12s,color .12s}.sidenav__item:hover{background:#ffffff0a;color:var(--text)}.sidenav__item.is-active{background:var(--accent-soft);color:#cfe0ff;font-weight:600;box-shadow:inset 2px 0 0 var(--accent)}.sidebar__footer{margin-top:auto;padding:16px;border-top:1px solid var(--border)}.main{flex:1;min-width:0;display:flex;flex-direction:column;height:100vh;overflow:auto}.topbar{position:sticky;top:0;z-index:5;background:#0a0d13d1;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:18px 28px;display:flex;align-items:center;justify-content:space-between}.topbar__title{font-size:18px;font-weight:600;letter-spacing:.1px}.content{flex:1;padding:24px 28px 60px;animation:ris-fade .22s ease}.card{background:var(--surface);border:1px solid var(--border);border-radius:13px;padding:20px}.tbl{width:100%;border-collapse:collapse}.tbl th{padding:13px 20px;text-align:left;border-bottom:1px solid rgba(255,255,255,.07);background:var(--surface-hd);color:var(--dim);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1px}.tbl td{padding:13px 20px;border-bottom:1px solid var(--border-row);vertical-align:middle}.tbl tr:last-child td{border-bottom:none}.tbl tr:hover td{background:#ffffff05}button{cursor:pointer;border:none;background:none;font:inherit;color:inherit}.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;border-radius:8px;font-weight:600;font-size:13px;cursor:pointer;transition:background .12s,color .12s,border-color .12s}.btn--primary{background:var(--accent);color:#fff;border:none;box-shadow:var(--accent-glow)}.btn--primary:hover{background:var(--accent-hover)}.btn--primary:disabled{opacity:.55;cursor:not-allowed}.btn--ghost{background:transparent;border:1px solid var(--border-ctrl);color:var(--text-2)}.btn--ghost:hover{background:#ffffff0d;border-color:#ffffff2e;color:var(--text)}.btn--ghost:disabled{opacity:.45;cursor:not-allowed}.btn--danger{background:var(--bad-soft);border:1px solid var(--bad-border);color:#f08a90}.btn--danger:hover{background:var(--bad);color:#fff;border-color:var(--bad)}.btn--sm{padding:6px 12px;font-size:12px;font-weight:500;border-radius:7px}input,select,textarea{font-family:inherit;font-size:13.5px;color:var(--text-2);background:#0d1219;border:1px solid var(--border-input);border-radius:9px;padding:10px 13px;width:100%;outline:none;transition:border-color .15s,box-shadow .15s}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #5b8def2e}select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:7px;font-size:11px;font-weight:600;letter-spacing:.5px;color:var(--text-3)}.form-error{color:var(--bad);font-size:12px;margin-top:10px}.badge{display:inline-block;padding:3px 9px;border-radius:6px;font-family:IBM Plex Mono,monospace;font-size:11px;font-weight:500;letter-spacing:.3px}.badge--draft{color:var(--warn);background:#e0a93b1f;border:1px solid rgba(224,169,59,.25)}.badge--published{color:var(--good);background:#5fd39a1f;border:1px solid rgba(95,211,154,.25)}.tab-strip{display:flex;gap:6px;padding:5px;background:var(--surface);border:1px solid var(--border);border-radius:11px;width:max-content;margin-bottom:22px}.tab-strip .btn--primary{box-shadow:0 4px 12px -4px #5b8defb3}.tab-strip .btn--ghost{border:none}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#04060bb3;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:flex-start;justify-content:center;padding:56px 20px;overflow:auto}.modal-box{background:var(--modal-bg);border:1px solid var(--border-input);border-radius:16px;box-shadow:0 30px 80px -20px #000000b3;animation:ris-pop .2s ease;width:100%;max-width:560px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 22px;border-bottom:1px solid var(--border)}.modal-header h2{font-size:17px;font-weight:600}.modal-body{padding:22px}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 22px;border-top:1px solid var(--border)}.login-wrap{display:flex;align-items:center;justify-content:center;min-height:100vh}.login-box{width:340px;background:var(--surface);border:1px solid var(--border);border-radius:13px;padding:32px}.login-box h1{font-size:20px;font-weight:600;margin-bottom:4px}.login-box p{color:var(--muted);font-size:13px;margin-bottom:24px}@media print{@page{size:A4 portrait;margin:1.2cm}.sidebar,.topbar,.btn,select,label,input,.form-group,[class*=btn],nav,.no-print{display:none!important}.main{display:block!important;height:auto!important;overflow:visible!important;padding:0!important}.content{padding:0!important;margin:0!important;overflow:visible!important;height:auto!important}*,*:before,*:after{background:#fff!important;color:#000!important;border-color:#ddd!important;box-shadow:none!important;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}body,html{background:#fff!important}.report-grid-cell-lesson{border-left-width:3px!important}.report-card{page-break-before:always;break-before:page;page-break-inside:avoid;break-inside:avoid}.report-card:first-child{page-break-before:auto;break-before:auto}.card{border:1px solid #ccc!important;border-radius:0!important}.tbl th{background:#f5f5f5!important;font-weight:700}.tbl th,.tbl td{border:1px solid #ccc!important;padding:5px 8px}}
