.layout{min-height:100vh;display:flex;flex-direction:column}.header{background-color:#fff;box-shadow:0 2px 4px #0000001a;margin-bottom:20px}.header .container{display:flex;justify-content:space-between;align-items:center;padding:15px 20px}.logo{text-decoration:none;color:#333}.logo h1{font-size:24px;margin:0}.nav{display:flex;gap:20px;align-items:center}.nav a{text-decoration:none;color:#666;font-weight:500;padding:5px 10px;border-radius:4px;transition:all .3s}.nav a:hover,.nav a.active{color:#007bff;background-color:#f0f8ff}.user-info{display:flex;align-items:center;gap:15px;margin-left:auto}.username{color:#666;font-size:14px}.btn-logout{background-color:#dc3545;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:14px;transition:background-color .3s}.btn-logout:hover{background-color:#c82333}.main{flex:1}.login-container{min-height:calc(100vh - 200px);display:flex;justify-content:center;align-items:center;padding:20px}.login-card{background:#fff;border-radius:8px;padding:40px;box-shadow:0 4px 6px #0000001a;width:100%;max-width:400px}.login-card h2{margin:0 0 30px;text-align:center;color:#333}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:#333}.form-group input{width:100%;padding:12px;border:1px solid #ddd;border-radius:5px;font-size:16px;transition:border-color .3s}.form-group input:focus{outline:none;border-color:#007bff}.error-message{background-color:#f8d7da;color:#721c24;padding:12px;border-radius:5px;margin-bottom:20px;border:1px solid #f5c6cb}.btn-block{width:100%;padding:12px;font-size:16px;margin-top:10px}.discipline-list{max-width:1200px;margin:0 auto}.list-item{min-height:120px;display:flex;justify-content:space-between;align-items:flex-start;padding:15px;border-bottom:1px solid #eee}.list-item-content{flex:1;min-width:0;padding-right:20px}.list-item-content h3{margin:0 0 10px;color:#333;font-size:18px}.description{color:#666;margin:5px 0;font-size:14px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;max-height:4.5em}.meta{margin-top:10px;font-size:14px;color:#999}.list-item-actions{display:flex;gap:10px;flex-shrink:0;flex-wrap:wrap}.loading,.empty-state{text-align:center;padding:40px;color:#666}@media (max-width: 768px){.list-item{flex-direction:column;align-items:stretch}.list-item-content{padding-right:0;margin-bottom:15px}.list-item-actions{justify-content:flex-start}}.form-container{max-width:800px;margin:0 auto}.form-container h2{margin-bottom:20px;color:#333}.topic-list{max-width:1200px;margin:0 auto}.btn-back{margin-right:15px;margin-bottom:10px}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;flex-wrap:wrap;gap:15px}.topics-container{display:flex;flex-direction:column;gap:20px}.topic-card{background:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a;min-height:200px;display:flex;flex-direction:column}.topic-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:15px;gap:15px;flex-shrink:0}.topic-header h3{margin:0;color:#333;flex:1;min-width:0;word-wrap:break-word}.topic-actions{display:flex;gap:10px;flex-shrink:0}.topic-actions .btn{white-space:nowrap;min-width:120px;height:36px;display:inline-flex;align-items:center;justify-content:center}.topic-description{color:#666;margin-bottom:15px;font-size:14px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;max-height:3em;flex-shrink:0}.tests-list{margin-top:auto;padding-top:20px;border-top:1px solid #eee;flex-grow:1;display:flex;flex-direction:column}.tests-list h4{margin:0 0 15px;color:#555;font-size:16px;flex-shrink:0}.test-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background:#f9f9f9;border-radius:5px;margin-bottom:10px;gap:15px;min-height:50px}.test-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.test-info strong{color:#333;display:block;word-wrap:break-word}.test-description{color:#666;font-size:13px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:1;line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;max-height:1.4em}.test-actions{display:flex;gap:10px;flex-shrink:0}.test-actions .btn{white-space:nowrap;min-width:100px;height:32px;display:inline-flex;align-items:center;justify-content:center;padding:6px 12px;font-size:14px}.tests-empty{margin-top:15px;padding:15px;text-align:center;color:#999;background:#f9f9f9;border-radius:5px}.tests-loading{margin-top:15px;padding:15px;text-align:center;color:#666}.btn-sm{padding:6px 12px;font-size:14px}.empty-state,.loading{text-align:center;padding:40px;color:#666}@media (max-width: 768px){.topic-card{min-height:auto}.topic-header{flex-direction:column;align-items:flex-start}.topic-actions{width:100%;justify-content:flex-start}.topic-actions .btn{flex:1;min-width:auto}.test-item{flex-direction:column;align-items:flex-start;gap:10px}.test-actions{width:100%;justify-content:flex-start}.test-actions .btn{flex:1;min-width:auto}}.subtitle{font-size:18px;font-weight:400;color:#666;margin-left:10px}.exam-list{max-width:1200px;margin:0 auto;width:100%}.exam-item{padding:25px;border:1px solid #e0e0e0;border-radius:8px;background:#fff;box-shadow:0 2px 4px #0000000d;transition:all .3s ease;margin-bottom:20px}.exam-item:last-child{margin-bottom:0}.exam-item:hover{box-shadow:0 4px 8px #0000001a;border-color:#007bff}.exam-item .list-item-content{margin-bottom:15px}.exam-item h3{margin:0 0 10px;color:#333;font-size:20px;font-weight:600}.exam-item .description{margin:10px 0;color:#666;font-size:14px;line-height:1.5}.exam-item .meta{margin-top:15px;padding-top:15px;border-top:1px solid #f0f0f0;color:#666;font-size:14px}.exam-item .meta span{font-weight:500}.referral-link-section{margin-top:15px;padding:15px;background:#f0f8ff;border-radius:5px;border:1px solid #cce7ff}.referral-link-section label{display:block;margin-bottom:8px;font-weight:600;color:#333;font-size:14px}.referral-link-container{display:flex;gap:10px;align-items:center}.referral-link-input{flex:1;padding:8px 12px;border:1px solid #ddd;border-radius:4px;background:#fff;font-size:14px;font-family:monospace;color:#333}.referral-link-input:focus{outline:none;border-color:#007bff}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.page-header h2{margin:0;color:#333;font-size:28px}.card{background:transparent;box-shadow:none;padding:0;margin-bottom:0}.list-item{display:flex;justify-content:space-between;align-items:flex-start;padding:0;border-bottom:none}.list-item-content{flex:1;min-width:0}.list-item-actions{display:flex;gap:10px;align-items:flex-start;margin-left:20px;flex-shrink:0}.empty-state{text-align:center;padding:60px 20px;color:#666;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d}.btn-sm{padding:6px 12px;font-size:13px}@media (max-width: 768px){.exam-list{max-width:100%}.exam-item{padding:15px}.list-item{flex-direction:column}.list-item-actions{margin-left:0;margin-top:15px;width:100%}.list-item-actions .btn{flex:1}.referral-link-container{flex-direction:column}.referral-link-input{width:100%}}.questions-section{margin-top:30px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-header h3{margin:0;color:#333}.question-card{background:#f9f9f9;border:1px solid #e0e0e0;border-radius:8px;padding:20px;margin-bottom:20px}.question-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.question-header h4{margin:0;color:#333}.answers-section{margin-top:20px}.answers-label{display:block;font-weight:600;color:#333;margin-bottom:15px;font-size:14px}.answer-item{display:flex;gap:10px;align-items:center;margin-bottom:10px;padding:10px;background:#fff;border-radius:5px}.answer-input{flex:1}.answer-input input{width:100%;padding:8px;border:1px solid #ddd;border-radius:4px}.answer-actions{display:flex;align-items:center;gap:10px}.answer-actions-bottom{margin-top:15px;padding-top:15px;border-top:1px solid #e0e0e0}.checkbox-label{display:flex;align-items:center;gap:5px;cursor:pointer;font-size:14px}.checkbox-label input[type=radio]{cursor:pointer}.question-actions-bottom{display:flex;justify-content:flex-end;gap:10px;margin-top:20px;padding-top:20px;border-top:2px solid #e0e0e0}.btn-sm{padding:5px 10px;font-size:14px}.form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.auto-save-status{font-size:14px;padding:5px 10px;border-radius:4px;font-weight:500}.auto-save-status.saving{color:#666;background-color:#f0f0f0}.auto-save-status.saved{color:#28a745;background-color:#d4edda}.auto-save-status.error{color:#dc3545;background-color:#f8d7da}.students-list{max-width:1200px;margin:0 auto}.table-container{overflow-x:auto}.students-table{width:100%;border-collapse:collapse;background:#fff}.students-table thead{background-color:#f8f9fa}.students-table th{padding:12px 15px;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #dee2e6;white-space:nowrap}.students-table td{padding:12px 15px;border-bottom:1px solid #dee2e6;color:#555}.students-table tbody tr:hover{background-color:#f8f9fa}.students-table tbody tr:last-child td{border-bottom:none}.students-table tbody tr.blocked-student{background-color:#fff5f5;opacity:.8}.students-table tbody tr.blocked-student:hover{background-color:#ffe5e5}.status-badge.active{background-color:#d4edda;color:#155724}.status-badge.blocked{background-color:#f8d7da;color:#721c24}.students-table td:last-child{text-align:center;white-space:nowrap}.students-table th:last-child{text-align:center}.btn-sm{padding:6px 12px;font-size:13px;white-space:nowrap}.error-message{background-color:#f8d7da;color:#721c24;padding:15px;border-radius:5px;margin-bottom:20px;border:1px solid #f5c6cb}@media (max-width: 768px){.students-table{font-size:14px}.students-table th,.students-table td{padding:8px 10px}.page-header{flex-direction:column;align-items:flex-start;gap:15px}}.exam-results-list{max-width:100%;margin:0 auto;width:100%;padding:0}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.page-header h2{margin:0;color:#333}.filters-section{background:#fff;padding:20px;border-radius:8px;margin-bottom:20px;box-shadow:0 2px 4px #0000001a}.filter-group{display:flex;gap:20px;margin-bottom:15px;flex-wrap:wrap}.filter-group label{display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:500;color:#555}.filter-group input[type=radio]{cursor:pointer}.filter-select{margin-top:10px}.form-select{width:100%;max-width:400px;padding:10px 15px;border:1px solid #ddd;border-radius:5px;font-size:14px;background:#fff;cursor:pointer}.form-select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.table-container{overflow-x:auto;width:100%}.results-table{width:100%;min-width:1400px;border-collapse:collapse;background:#fff;table-layout:auto}.results-table thead{background-color:#f8f9fa}.results-table th{padding:12px 15px;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #dee2e6;white-space:nowrap}.results-table td{padding:12px 15px;border-bottom:1px solid #dee2e6;color:#555;white-space:nowrap}.results-table td:first-child{width:50px}.results-table td:nth-child(2){min-width:200px;white-space:normal}.results-table td:nth-child(3){min-width:200px;white-space:normal}.results-table td:nth-child(4),.results-table td:nth-child(5){width:100px;text-align:center}.results-table td:nth-child(6){width:120px}.results-table td:nth-child(7){min-width:150px}.results-table td:last-child{min-width:150px;width:150px;text-align:center;white-space:nowrap;padding:12px 10px}.results-table th:last-child{min-width:150px;width:150px;text-align:center;white-space:nowrap}.results-table tbody tr:hover{background-color:#f8f9fa}.results-table tbody tr:last-child td{border-bottom:none}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase}.status-badge.passed{background-color:#d4edda;color:#155724}.status-badge.failed{background-color:#f8d7da;color:#721c24}.table-footer{padding:15px;background-color:#f8f9fa;border-top:1px solid #dee2e6;color:#666;font-size:14px}.loading{text-align:center;padding:40px;color:#666}.error-message{background-color:#f8d7da;color:#721c24;padding:15px;border-radius:5px;margin-bottom:20px;border:1px solid #f5c6cb;display:flex;align-items:center}.card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.btn{padding:8px 16px;border:none;border-radius:5px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s}.btn-danger{background-color:#dc3545;color:#fff;padding:6px 12px;font-size:13px}.btn-sm{padding:4px 10px;font-size:12px}.student-name-link{background:none;border:none;color:#007bff;cursor:pointer;text-decoration:underline;padding:0;font-size:inherit;font-family:inherit}.student-name-link:hover{color:#0056b3;text-decoration:none}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:8px;max-width:900px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 4px 20px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #dee2e6}.modal-header h3{margin:0;color:#333}.modal-close{background:none;border:none;font-size:28px;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s}.modal-close:hover{background-color:#f0f0f0;color:#333}.modal-body{padding:20px;overflow-y:auto;flex:1}.modal-footer{padding:15px 20px;border-top:1px solid #dee2e6;display:flex;justify-content:flex-end}.result-details{display:flex;flex-direction:column;gap:20px}.result-summary{background-color:#f8f9fa;padding:15px;border-radius:5px;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px}.summary-item{display:flex;flex-direction:column;gap:5px}.summary-item strong{color:#666;font-size:12px;text-transform:uppercase}.questions-list{display:flex;flex-direction:column;gap:20px}.questions-list h4{margin:0 0 15px;color:#333;font-size:18px}.question-detail{border:1px solid #dee2e6;border-radius:8px;padding:15px;background:#fff}.question-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.question-number{font-weight:600;color:#333;font-size:16px}.question-status{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.question-status.correct{background-color:#d4edda;color:#155724}.question-status.incorrect{background-color:#f8d7da;color:#721c24}.question-text{font-size:15px;color:#333;margin-bottom:15px;line-height:1.5}.answers-section{display:flex;flex-direction:column;gap:15px}.student-answer-block{color:#fff;padding:15px;border-radius:8px;margin-bottom:10px;border:3px solid;transition:all .3s}.student-answer-block.student-answer-correct{background:linear-gradient(135deg,#28a745,#20c997);border-color:#28a745;box-shadow:0 2px 8px #28a74566}.student-answer-block.student-answer-incorrect{background:linear-gradient(135deg,#dc3545,#c82333);border-color:#dc3545;box-shadow:0 2px 8px #dc354566;border-width:3px}.student-answer-label{font-size:13px;opacity:.9;margin-bottom:8px}.student-answer-label strong{font-weight:600}.student-answer-content{font-size:16px;font-weight:500;line-height:1.5;padding:10px;background:#ffffff26;border-radius:5px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.answers-label{font-weight:600;color:#666;font-size:14px;margin-bottom:5px;margin-top:5px}.answer-item{padding:12px;border:2px solid #dee2e6;border-radius:5px;display:flex;justify-content:space-between;align-items:center;background:#fff;transition:all .2s}.answer-item.correct-answer{border-color:#28a745;background-color:#d4edda;border-width:3px}.answer-item.student-answer{border-color:#007bff;background-color:#e7f3ff;border-width:3px;box-shadow:0 0 0 2px #007bff33}.answer-item.student-answer-correct{border-color:#28a745;background-color:#d4edda;box-shadow:0 0 0 2px #28a74533}.answer-item.student-answer-incorrect-item{border-color:#dc3545!important;background-color:#f8d7da!important;border-width:3px!important;box-shadow:0 0 0 3px #dc35454d!important}.answer-item.correct-answer.student-answer{border-color:#28a745;background-color:#d4edda;box-shadow:0 0 0 2px #28a74533}.answer-text{flex:1;color:#333}.answer-badges{display:flex;gap:8px;align-items:center}.answer-badge{padding:5px 12px;border-radius:12px;font-size:11px;font-weight:600;white-space:nowrap}.correct-badge{background-color:#28a745;color:#fff}.student-badge{background-color:#007bff;color:#fff;font-weight:700}.no-questions{text-align:center;padding:40px;color:#666}@media (max-width: 768px){.results-table{font-size:14px}.results-table th,.results-table td{padding:8px 10px}.page-header{flex-direction:column;align-items:flex-start;gap:15px}.filter-group{flex-direction:column;gap:10px}.form-select{max-width:100%}.modal-content{max-width:100%;max-height:95vh}.modal-body{padding:15px}.result-summary{grid-template-columns:1fr}.question-header{flex-direction:column;align-items:flex-start;gap:10px}.answer-item{flex-direction:column;align-items:flex-start;gap:8px}.answer-badge{margin-left:0}}.app{min-height:100vh}.container{max-width:100%;margin:0 auto;padding:20px;width:100%}.btn{padding:10px 20px;border:none;border-radius:5px;cursor:pointer;font-size:16px;transition:all .3s}.btn-primary{background-color:#007bff;color:#fff}.btn-primary:hover{background-color:#0056b3}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover{background-color:#545b62}.btn-danger{background-color:#dc3545;color:#fff}.btn-danger:hover{background-color:#c82333}.btn-success{background-color:#28a745;color:#fff}.btn-success:hover{background-color:#218838}.card{background:#fff;border-radius:8px;padding:20px;margin-bottom:20px;box-shadow:0 2px 4px #0000001a}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:5px;font-weight:600;color:#333}.form-group input,.form-group textarea{width:100%;padding:10px;border:1px solid #ddd;border-radius:5px;font-size:16px}.form-group textarea{min-height:100px;resize:vertical}.form-actions{display:flex;gap:10px;margin-top:20px}.list-item{display:flex;justify-content:space-between;align-items:center;padding:15px;border-bottom:1px solid #eee}.list-item:last-child{border-bottom:none}.list-item-content{flex:1}.list-item-actions{display:flex;gap:10px}.empty-state{text-align:center;padding:40px;color:#666}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
