*,*:before,*:after{box-sizing:border-box}:root{--bg: #0f1419;--surface: #1a2332;--surface-2: #243044;--border: #2d3a4f;--text: #e8edf5;--text-muted: #94a3b8;--primary: #3b82f6;--primary-hover: #2563eb;--success: #22c55e;--warning: #f59e0b;--danger: #ef4444;--radius: 10px;--shadow: 0 4px 24px rgba(0, 0, 0, .25);--bp-tablet: 768px;--bp-desktop: 1024px;--space-page: 1.5rem;--header-height: 56px;--touch-min: 44px;font-family:Segoe UI,system-ui,-apple-system,sans-serif;line-height:1.5;color:var(--text);background:var(--bg)}html{-webkit-text-size-adjust:100%}body{margin:0;min-height:100vh;padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);padding-bottom:env(safe-area-inset-bottom)}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}button,input,select,textarea{font:inherit}button{cursor:pointer}h1,h2,h3,h4{margin:0 0 .75rem;line-height:1.2}p{margin:0 0 1rem}code,pre{font-family:Cascadia Code,Fira Code,Consolas,monospace}.app-shell{min-height:100vh;display:flex;flex-direction:column}.app-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1.5rem;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.app-brand{font-weight:700;font-size:1.25rem;color:var(--text);text-decoration:none}.app-brand:hover{text-decoration:none;color:var(--primary)}.app-nav{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.app-nav a{color:var(--text-muted);text-decoration:none;font-weight:500}.app-nav a:hover,.app-nav a.active{color:var(--text)}.app-main{flex:1;padding:1.5rem;max-width:1200px;width:100%;margin:0 auto}.page-title{margin-bottom:1.5rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow)}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.card-link{display:block;color:inherit;text-decoration:none;transition:transform .15s,border-color .15s}.card-link:hover{transform:translateY(-2px);border-color:var(--primary);text-decoration:none}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.55rem 1rem;border-radius:8px;border:1px solid transparent;font-weight:600;transition:background .15s,border-color .15s}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-secondary{background:var(--surface-2);color:var(--text);border-color:var(--border)}.btn-secondary:hover:not(:disabled){border-color:var(--primary)}.btn-danger{background:var(--danger);color:#fff}.btn:disabled{opacity:.6;cursor:not-allowed}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.35rem;font-weight:600;color:var(--text-muted);font-size:.9rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.6rem .75rem;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:2px solid var(--primary);outline-offset:1px}.error-banner{background:#ef444426;border:1px solid var(--danger);color:#fecaca;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem}.success-banner{background:#22c55e26;border:1px solid var(--success);color:#bbf7d0;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem}.loading{text-align:center;padding:2rem;color:var(--text-muted)}.table-wrap{overflow-x:auto}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:.65rem .75rem;text-align:left;border-bottom:1px solid var(--border)}.data-table th{color:var(--text-muted);font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.badge{display:inline-block;padding:.15rem .5rem;border-radius:999px;font-size:.75rem;font-weight:600;background:var(--surface-2);color:var(--text-muted)}.badge-success{background:#22c55e33;color:#86efac}.badge-warning{background:#f59e0b33;color:#fcd34d}.badge-info{background:#3b82f633;color:#93c5fd}.badge-danger{background:#ef444433;color:#fca5a5}.stats-row{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1.5rem}.stat-card{flex:1;min-width:140px;background:var(--surface-2);border-radius:var(--radius);padding:1rem}.stat-card .stat-value{font-size:1.75rem;font-weight:700;color:var(--primary)}.stat-card .stat-label{color:var(--text-muted);font-size:.85rem}.student-badges-grid{display:grid;gap:.75rem;margin-top:.75rem}.student-badge-card{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem 1rem}.student-badge-icon{font-size:1.75rem;line-height:1;flex-shrink:0}.student-badge-body{flex:1;min-width:0}.profile-header{display:flex;align-items:center;gap:1.25rem;padding:1.25rem}.profile-avatar{flex-shrink:0;width:4.5rem;height:4.5rem;border-radius:50%;overflow:hidden;background:var(--surface-2, #eef2f7);display:flex;align-items:center;justify-content:center}.profile-avatar-img{width:100%;height:100%;object-fit:cover}.profile-avatar-fallback{font-size:1.75rem;font-weight:700;color:var(--primary)}.profile-name{margin:0;font-size:1.5rem}.profile-settings-form{padding:1.25rem;max-width:32rem}.profile-settings-preview{margin-bottom:.75rem}.profile-settings-preview .profile-avatar-img{width:5rem;height:5rem;border-radius:50%;object-fit:cover;border:2px solid var(--border)}.user-info{color:inherit;text-decoration:none}.user-info:hover{text-decoration:underline}.profile-link{color:var(--primary);font-weight:600;text-decoration:underline;text-underline-offset:2px;cursor:pointer}.profile-link:hover{color:var(--primary-hover)}.data-table .profile-link{display:inline-block;padding:.1rem 0}.checkbox-row-with-link{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.35rem}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem}.login-card{width:100%;max-width:400px}.lesson-layout{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.theory-panel{max-height:70vh;overflow-y:auto}.theory-panel pre{background:var(--bg);padding:1rem;border-radius:8px;overflow-x:auto}.editor-panel{display:flex;flex-direction:column;gap:.75rem}.editor-toolbar{display:flex;flex-direction:column;gap:.5rem}.editor-toolbar-primary,.editor-toolbar-secondary{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}.editor-toolbar .spacer{flex:1}.btn-sm{padding:.35rem .65rem;font-size:.85rem}.hint-text{color:var(--text-muted);font-size:.85rem;line-height:1.45;margin:0 0 .35rem}.hint-text code{font-size:.8rem;background:var(--surface-2);padding:.1rem .35rem;border-radius:4px}.toolbar-hints{margin-top:-.25rem}.editor-label-block{margin-bottom:.25rem}.editor-section-label{display:block;font-weight:600;font-size:.95rem;margin-bottom:.15rem}.practice-steps{display:flex;flex-wrap:wrap;gap:.35rem .5rem;list-style:none;margin:0 0 .75rem;padding:0}.practice-step{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .6rem;border-radius:999px;font-size:.8rem;background:var(--surface-2);color:var(--text-muted);border:1px solid var(--border)}.practice-step-active{border-color:var(--primary);color:var(--text);background:#3b82f61f}.practice-step-done{border-color:var(--success);color:#86efac;background:#22c55e1a}.practice-step-marker{display:inline-flex;align-items:center;justify-content:center;width:1.25rem;height:1.25rem;border-radius:50%;font-size:.7rem;font-weight:700;background:var(--bg)}.practice-step-active .practice-step-marker{background:var(--primary);color:#fff}.practice-step-done .practice-step-marker{background:var(--success);color:#fff}.task-tabs{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.5rem}.task-tab{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem .75rem;border-radius:8px;border:1px solid var(--border);background:var(--surface-2);color:var(--text-muted);font-size:.85rem;font-weight:600;cursor:pointer}.task-tab:hover{border-color:var(--primary);color:var(--text)}.task-tab-active{border-color:var(--primary);background:#3b82f61f;color:var(--text)}.task-tab-num{display:inline-flex;align-items:center;justify-content:center;min-width:1.25rem;height:1.25rem;padding:0 .25rem;border-radius:999px;background:var(--bg);font-size:.75rem}.task-goal-card{margin-bottom:.5rem}.task-goal-title{margin:0 0 .5rem;font-size:1.05rem}.task-goal-description{color:var(--text-muted);white-space:pre-wrap;margin:0 0 .65rem;line-height:1.5}.badge-xp{background:#f59e0b26;color:#fcd34d}.output-panels{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.output-panels-stacked{grid-template-columns:1fr}@media (max-width: 768px){.output-panels{grid-template-columns:1fr}}.output-panel{background:var(--bg);border:1px solid var(--border);border-radius:8px;overflow:hidden}.output-panel-main .output-panel-body{min-height:100px;max-height:200px}.output-panel-error{border-color:#ef444459}.output-panel-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.4rem .6rem;font-size:.8rem;font-weight:600;color:var(--text);background:var(--surface-2);border-bottom:1px solid var(--border)}.output-panel-hint{padding:.35rem .6rem 0;margin:0}.output-meta{font-size:.75rem;font-weight:500;color:var(--text-muted)}.output-empty{padding:1rem .75rem;margin:0;min-height:80px}.output-panel-body{padding:.6rem;min-height:80px;max-height:160px;overflow:auto;white-space:pre-wrap;font-family:Cascadia Code,Consolas,monospace;font-size:.85rem}.admin-layout{display:grid;grid-template-columns:220px 1fr;gap:1.5rem;align-items:start}.admin-sidebar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}.admin-sidebar nav{display:flex;flex-direction:column;gap:.25rem}.admin-sidebar a{padding:.5rem .75rem;border-radius:6px;color:var(--text-muted);text-decoration:none}.admin-sidebar a:hover,.admin-sidebar a.active{background:var(--surface-2);color:var(--text);text-decoration:none}.admin-actions{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;width:100%;max-width:480px;max-height:90vh;overflow-y:auto}.modal-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:1rem}.markdown-body h2,.markdown-body h3{margin-top:1.25rem}.markdown-body ul{padding-left:1.25rem}.user-info{display:flex;align-items:center;gap:.5rem;color:var(--text-muted);font-size:.9rem}.badge-icon-preview{position:relative;display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:8px;border:2px solid transparent}.badge-crown{position:absolute;top:-6px;right:-4px;font-size:.75rem;line-height:1}.badge-level-pill{display:inline-block;padding:.15rem .5rem;border-radius:999px;font-size:.8rem;border:1px solid transparent}.badge-level-bronze{border-color:#cd7f32;background:#cd7f3226;color:#e8a86b}.badge-level-silver{border-color:#a8a8a8;background:#a8a8a826;color:#d4d4d4}.badge-level-gold{border-color:gold;background:#ffd7001f;color:#ffe566}.badge-level-platinum{border-color:#7fdbda;background:#7fdbda1f;color:#a8f0ef}.badge-level-legendary{border-color:#c77dff;background:linear-gradient(135deg,#c77dff33,#ffd70026);color:#e0b3ff}.info-banner{background:#3b82f61f;border:1px solid rgba(59,130,246,.35);color:#93c5fd;padding:.75rem 1rem;border-radius:var(--radius)}.code-block{background:var(--bg);padding:1rem;border-radius:8px;overflow:auto;white-space:pre-wrap;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.9rem;border:1px solid var(--border)}.code-block-error{border-color:#ef444466}.modal-wide{max-width:720px}.toast-container{position:fixed;top:calc(var(--header-height) + .75rem);right:1rem;z-index:1000;display:flex;flex-direction:column;gap:.75rem;max-width:min(360px,calc(100vw - 2rem));pointer-events:none}.badge-toast{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);pointer-events:auto;animation:toast-slide-in .35s ease-out}@keyframes toast-slide-in{0%{opacity:0;transform:translate(1.5rem)}to{opacity:1;transform:translate(0)}}.badge-toast-icon{flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--surface-2)}.badge-toast-icon-img{width:36px;height:36px;object-fit:contain}.badge-toast-icon-emoji{font-size:1.75rem;line-height:1}.badge-toast-body{flex:1;min-width:0}.badge-toast-title{margin:0 0 .25rem;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--warning);font-weight:600}.badge-toast-name{margin:0 0 .25rem;font-weight:600;font-size:1rem}.badge-toast-desc{margin:0;font-size:.85rem;color:var(--text-muted);line-height:1.4}.badge-toast-close{flex-shrink:0;background:none;border:none;color:var(--text-muted);font-size:1.25rem;line-height:1;padding:0;cursor:pointer;min-height:auto}.badge-toast-close:hover{color:var(--text)}.text-muted{color:var(--text-muted)}.btn-block{width:100%}.btn-compact{padding:.3rem .6rem;font-size:.85rem}.page-header-row{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.page-header-row .page-title{margin-bottom:0}.mt-sm{margin-top:.75rem}.mt-md{margin-top:1rem}.mt-lg{margin-top:1.5rem}.mt-xl{margin-top:2rem}.mt-auto{margin-top:auto}.mb-md{margin-bottom:1rem}.mb-lg{margin-bottom:1.5rem}.mr-sm{margin-right:.5rem}.text-sm{font-size:.9rem}.flex-wrap-gap{display:flex;gap:.5rem;flex-wrap:wrap}.flex-wrap-gap-lg{display:flex;gap:.75rem;flex-wrap:wrap}.form-narrow{margin-top:1rem;max-width:320px}.checkbox-list label{display:block;margin-bottom:.5rem}.checkbox-list-bordered{max-height:120px;overflow-y:auto;border:1px solid var(--border);border-radius:8px;padding:.5rem}.checkbox-list-bordered label{margin-bottom:.25rem}.badge-icon-sm{width:32px;height:32px;object-fit:contain;vertical-align:middle}.icon-fallback{font-size:1.5rem}.card-compact{margin-bottom:1rem;padding:.75rem}.row-locked{opacity:.65}.scroll-y-sm{max-height:240px;overflow-y:auto;margin-top:.5rem}.scroll-y-md{max-height:180px;overflow-y:auto;margin-top:.5rem}.pre-wrap{white-space:pre-wrap}.text-center-muted{text-align:center;color:var(--text-muted)}.form-row-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}.code-textarea{font-family:Cascadia Code,Fira Code,Consolas,monospace;font-size:.9rem}.editor-wrap{position:relative;min-height:240px;height:min(320px,40vh)}.lesson-cards{display:none}.lesson-card{padding:1rem;border-bottom:1px solid var(--border)}.lesson-card:last-child{border-bottom:none}.lesson-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem;margin-bottom:.5rem}.lesson-card-title{font-weight:600;margin:0}.lesson-card-goal{color:var(--text-muted);font-size:.9rem;margin:0 0 .75rem}.lesson-card-footer{display:flex;justify-content:space-between;align-items:center;gap:.5rem;flex-wrap:wrap}.app-header-toggle{display:none;min-height:var(--touch-min);min-width:var(--touch-min);padding:.5rem;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;color:var(--text)}.app-nav-overlay,.app-nav-mobile-panel,.admin-tabs{display:none}.admin-sidebar-desktop{display:block}@media (max-width: 1024px){.lesson-layout{grid-template-columns:1fr}}@media (max-width: 768px){:root{--space-page: 1rem}.toast-container{left:1rem;right:1rem;max-width:none}.app-main{padding:var(--space-page)}.app-header{padding:.5rem var(--space-page)}.app-header-toggle{display:inline-flex;align-items:center;justify-content:center}.app-nav-desktop{display:none}.app-nav-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:90;opacity:0;pointer-events:none;transition:opacity .2s}.app-nav-overlay.nav-open{opacity:1;pointer-events:auto}.app-nav-mobile-panel{display:flex;flex-direction:column;gap:.25rem;position:fixed;top:0;right:0;width:min(280px,85vw);height:100%;background:var(--surface);border-left:1px solid var(--border);padding:1rem;padding-top:calc(1rem + env(safe-area-inset-top));z-index:100;transform:translate(100%);transition:transform .2s;overflow-y:auto}.app-nav-mobile-panel.nav-open{transform:translate(0)}.app-nav-mobile-panel a,.app-nav-mobile-panel .btn{min-height:var(--touch-min);display:flex;align-items:center;padding:.65rem .75rem;border-radius:8px;color:var(--text-muted);text-decoration:none;font-weight:500}.app-nav-mobile-panel a:hover,.app-nav-mobile-panel a.active{background:var(--surface-2);color:var(--text);text-decoration:none}.app-nav-mobile-user{padding:.65rem .75rem;color:var(--text-muted);font-size:.9rem;border-bottom:1px solid var(--border);margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{font-size:16px}.btn,.task-tab{min-height:var(--touch-min)}.stats-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.stat-card{min-width:0}.card-grid{grid-template-columns:1fr}.theory-panel{max-height:none}.practice-steps{flex-direction:column;align-items:stretch}.practice-step{border-radius:8px;width:100%}.editor-wrap{height:min(240px,35vh)}.editor-toolbar-primary,.editor-toolbar-secondary{flex-direction:column;align-items:stretch}.editor-toolbar-primary .btn,.editor-toolbar-secondary .btn{width:100%}.admin-layout{grid-template-columns:1fr;gap:0}.admin-sidebar-desktop{display:none}.admin-tabs{display:flex;gap:.35rem;overflow-x:auto;padding:.5rem 0;margin-bottom:1rem;-webkit-overflow-scrolling:touch}.admin-tabs a{flex-shrink:0;padding:.5rem .75rem;border-radius:999px;border:1px solid var(--border);background:var(--surface-2);color:var(--text-muted);text-decoration:none;font-size:.85rem;white-space:nowrap;min-height:var(--touch-min);display:inline-flex;align-items:center}.admin-tabs a:hover,.admin-tabs a.active{border-color:var(--primary);color:var(--text);text-decoration:none}.data-table .col-hide-mobile{display:none}.data-table th,.data-table td{padding:.5rem;font-size:.9rem}.course-table-desktop{display:none}.lesson-cards{display:block}.modal-backdrop{align-items:flex-end;padding:0}.modal,.modal-wide{max-width:100%;max-height:85vh;border-radius:var(--radius) var(--radius) 0 0;margin:0}.modal-actions{flex-direction:column-reverse}.modal-actions .btn{width:100%}.page-title{font-size:1.35rem}}@media (min-width: 769px) and (max-width: 1023px){.card-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}}
