*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f9f9f8;--surface: #ffffff;--border: #e2e2e0;--text: #1a1a18;--muted: #6b6b67;--accent: #2563eb;--accent-hover: #1d4ed8;--danger: #dc2626;--success: #16a34a;--radius: 8px;--shadow: 0 1px 3px rgba(0,0,0,.08)}body{font-family:system-ui,-apple-system,sans-serif;font-size:15px;line-height:1.5;background:var(--bg);color:var(--text)}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.centered{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem;padding:2rem}.appShell{display:grid;grid-template-rows:auto 1fr;min-height:100vh}.nav{display:flex;align-items:center;gap:1.5rem;padding:.75rem 1.5rem;background:var(--surface);border-bottom:1px solid var(--border)}.nav .brand{font-weight:700;font-size:1.1rem;color:var(--text)}.nav a{color:var(--muted);font-size:.9rem}.nav a:hover,.nav a.active{color:var(--accent);text-decoration:none}.nav .spacer{flex:1}.main{padding:2rem 1.5rem;max-width:960px;margin:0 auto;width:100%}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--shadow)}.panel h2{font-size:1.1rem;margin-bottom:1rem}.panel h3{font-size:.95rem;margin-bottom:.75rem;color:var(--muted)}.formStack{display:flex;flex-direction:column;gap:.75rem}.formStack label{display:flex;flex-direction:column;gap:.25rem;font-size:.85rem;font-weight:500}.formStack input,.formStack select,.formStack textarea{padding:.5rem .75rem;border:1px solid var(--border);border-radius:6px;font-size:.95rem;background:var(--bg);color:var(--text);width:100%}.formStack input:focus,.formStack select:focus,.formStack textarea:focus{outline:2px solid var(--accent);outline-offset:1px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;border-radius:6px;border:none;font-size:.9rem;font-weight:500;cursor:pointer;background:var(--accent);color:#fff;transition:background .15s}.btn:hover{background:var(--accent-hover)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.ghost{background:transparent;color:var(--accent);border:1px solid var(--border)}.btn.ghost:hover{background:var(--bg)}.btn.danger{background:var(--danger)}.btn.danger:hover{background:#b91c1c}.buttonRow{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}.tableWrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:.9rem}th{text-align:left;padding:.5rem .75rem;background:var(--bg);font-size:.8rem;font-weight:600;color:var(--muted);border-bottom:1px solid var(--border)}td{padding:.5rem .75rem;border-bottom:1px solid var(--border)}tr:last-child td{border-bottom:none}.errorText{color:var(--danger);font-size:.9rem}.successText{color:var(--success);font-size:.9rem}.smallText{font-size:.82rem;color:var(--muted)}.tabNav{display:flex;gap:.25rem;border-bottom:1px solid var(--border);margin-bottom:1.5rem}.tabNav a{padding:.5rem 1rem;color:var(--muted);font-size:.9rem;border-bottom:2px solid transparent;margin-bottom:-1px}.tabNav a:hover{color:var(--text);text-decoration:none}.tabNav a.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:500}.assignmentList{display:flex;flex-direction:column;gap:.75rem}.assignmentCard{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;box-shadow:var(--shadow)}.assignmentCard .meta{display:flex;flex-direction:column;gap:.2rem}.assignmentCard .title{font-weight:600}.assignmentCard .sub{font-size:.82rem;color:var(--muted)}.assignmentCard .badge{font-size:.78rem;font-weight:600;padding:.2rem .6rem;border-radius:999px;background:var(--bg);border:1px solid var(--border);color:var(--muted);white-space:nowrap}.assignmentCard .badge.submitted{background:#dcfce7;color:var(--success);border-color:#bbf7d0}.assignmentCard .badge.overdue{background:#fee2e2;color:var(--danger);border-color:#fecaca}.lessonRunnerPage{display:flex;flex-direction:column;height:100vh}.lessonRunnerFrame{flex:1;border:none;width:100%}
