*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:#fff;min-height:100vh;color:#000}#root{min-height:100vh;display:flex;align-items:flex-start;justify-content:center;padding:20px;background:#fff}.app{background:#fff;border-radius:16px;box-shadow:none;max-width:900px;width:100%;padding:40px}.logo-container{display:flex;justify-content:center;margin-bottom:20px}.logo{display:block;max-width:100%;height:auto}.app-logo{margin-bottom:5px}.auth-logo,.auth-container .auth-logo{margin-bottom:15px}.app h1{text-align:center;color:#000;margin-bottom:30px;font-size:2.5em;font-weight:700;letter-spacing:-1px}.upload-form{background:#f5f5f5;padding:25px;border-radius:12px;margin-bottom:30px;border:2px solid #000000}.upload-form h2{color:#000;margin-bottom:15px;font-size:1.3em;font-weight:600}.form-group{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.file-input{padding:12px 15px;border:2px solid #000000;border-radius:8px;cursor:pointer;flex:1;min-width:200px;transition:all .3s;background:#fff;color:#000;font-weight:500}.file-input:hover{background:#f5f5f5}.btn{padding:12px 25px;border:2px solid #000000;border-radius:8px;font-size:1em;cursor:pointer;transition:all .3s;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.btn-primary{background:#000;color:#fff}.btn-primary:hover:not(:disabled){background:#333;border-color:#333;transform:translateY(-2px);box-shadow:0 8px 16px #0003}.btn:disabled{opacity:.5;cursor:not-allowed}.status-message{padding:12px;border-radius:6px;margin-top:10px;font-weight:500;border-left:4px solid}.status-success{background:#f0f0f0;color:#000;border-left-color:#000}.status-error{background:#ffebee;color:#c62828;border-left-color:#c62828}.quiz-section{margin-top:30px}.quiz-section h3{color:#000;margin-bottom:20px;font-size:1.5em;font-weight:700;border-bottom:3px solid #000000;padding-bottom:10px;text-transform:uppercase;letter-spacing:.5px}.question{background:#f9f9f9;padding:20px;margin-bottom:20px;border-radius:12px;border:2px solid #000000}.question p{font-weight:600;color:#000;margin-bottom:15px;font-size:1.05em}.options{display:flex;flex-direction:column;gap:10px}.option-label{display:flex;align-items:center;padding:12px;background:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .3s;color:#000;font-weight:500}.option-label:hover{border-color:#000;background:#f5f5f5}.option-label input[type=radio]{margin-right:12px;width:18px;height:18px;cursor:pointer;accent-color:#000000}.question-comment{margin-top:10px;padding:10px;background:#fffbf0;border-left:3px solid #000000;color:#000;border-radius:8px;font-size:.9em;font-weight:500}.btn-container{display:flex;justify-content:center;gap:10px;margin-top:30px;flex-wrap:wrap}.btn-submit{padding:15px 40px;font-size:1.1em}.result{margin-top:30px;padding:0;background:#f5f5f5;color:#000;border-radius:0;border:2px solid #000000;overflow:hidden}.result h3{color:#000;margin:0;padding:0;font-size:1.5em;font-weight:700;text-transform:uppercase;letter-spacing:.5px;display:none}.score-display{font-weight:700;color:#000;padding:30px;background:transparent;text-align:center;border:none;margin:0 0 25px;border-radius:0}.score-number{font-size:2em;text-transform:uppercase;letter-spacing:1px;margin-bottom:15px}.score-details{font-size:1.1em;display:flex;justify-content:center;gap:15px;flex-wrap:wrap}.score-details .correct{color:#388e3c;font-weight:600}.score-details .wrong{color:#d32f2f;font-weight:600}.score-details .no-answer{color:#f57f17;font-weight:600}.score-details .separator{color:#999}.results-list{list-style:none;padding:0 25px 25px;margin:0}.result-item{background:#fff;padding:25px;margin-bottom:20px;border-radius:12px;border:2px solid #000000;color:#000}.result-item.incorrect{border-color:#d32f2f}.result-item strong{display:block;margin-bottom:15px;color:#000;font-weight:700;font-size:1.05em}.result-item-details{font-size:.95em;line-height:1.8;color:#333;margin-bottom:15px}.result-item-details .your-answer{color:#d32f2f;font-weight:600}.result-item-details .correct-answer{color:#388e3c;font-weight:600}.result-item-comment{margin-top:15px;padding:12px;background:#fff9e6;border-radius:6px;color:#f57f17;font-size:.9em;border-left:3px solid #f57f17;font-weight:500}.options-list{margin-top:12px;margin-bottom:0;display:flex;flex-direction:column;gap:10px;padding:15px;background:#fff;border-radius:0;border:1px solid #e0e0e0}.option-result{padding:12px;background:#fff;border-left:3px solid #bdbdbd;color:#424242;border-radius:8px;font-size:.95em;font-weight:500}.option-result.correct-option{border-left-color:#388e3c;background:#f1f8e9;color:#2e7d32;font-weight:600}.option-result.incorrect-option{border-left-color:#d32f2f;background:#ffebee;color:#c62828;font-weight:600}.loading{text-align:center;padding:20px;color:#000;font-weight:500}.error-message{background:#ffebee;color:#c62828;padding:15px;border-radius:8px;border-left:4px solid #c62828;margin:15px 0;font-weight:500}.error-message strong{display:block;margin-bottom:8px;font-size:1.05em}.error-message p{margin:0;line-height:1.5}.warning-message{background:#fff3e0;color:#e65100;padding:15px;border-radius:8px;border-left:4px solid #ff9800;margin:15px 0;font-weight:500}.warning-message strong{display:block;margin-bottom:8px;font-size:1.05em}.warning-message ul{margin:0;padding-left:20px}.warning-message li{margin:5px 0;line-height:1.5}@media(max-width:768px){.app{padding:20px}.app h1{font-size:1.8em}.form-group{flex-direction:column}.file-input{min-width:100%}.btn-container{flex-direction:column}.btn{width:100%}}.auth-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;background:#fff;padding:10px 20px 20px}.auth-box{background:#fff;border-radius:16px;border:2px solid #000000;padding:40px;max-width:400px;width:100%}.auth-box h2{color:#000;margin-bottom:30px;font-size:2em;text-align:center;font-weight:700}.auth-form{display:flex;flex-direction:column;gap:20px}.form-field{display:flex;flex-direction:column;gap:8px}.form-field label{color:#000;font-weight:600;font-size:.95em}.auth-input{padding:12px 15px;border:2px solid #e0e0e0;border-radius:8px;font-size:1em;transition:all .3s;background:#fff;color:#000}.auth-input:focus{outline:none;border-color:#000}.auth-btn{width:100%;margin-top:10px}.auth-toggle{margin-top:20px;text-align:center;color:#666}.toggle-link{background:none;border:none;color:#000;font-weight:600;cursor:pointer;text-decoration:underline;padding:0}.toggle-link:hover{color:#333}.guest-mode-section{margin-top:30px}.divider{text-align:center;position:relative;margin:20px 0}.divider:before,.divider:after{content:"";position:absolute;top:50%;width:45%;height:1px;background:#e0e0e0}.divider:before{left:0}.divider:after{right:0}.divider span{background:#fff;padding:0 10px;color:#999;font-size:.9em}.guest-btn{width:100%;background:#fff;color:#000;border:2px solid #e0e0e0}.guest-btn:hover{background:#f5f5f5;border-color:#000}.guest-notice-text{text-align:center;color:#999;font-size:.85em;margin-top:10px}.guest-notice{background:#fffbf0;border:2px solid #f57f17;border-radius:12px;padding:20px;margin-bottom:30px;text-align:center}.guest-notice p{color:#000;margin-bottom:15px;font-size:1.05em}.guest-notice strong{color:#f57f17}.btn-secondary{background:#fff;color:#000;border:2px solid #000000}.btn-secondary:hover{background:#000;color:#fff}.dashboard{background:#f5f5f5;padding:25px;border-radius:12px;margin-bottom:30px;border:2px solid #000000}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.dashboard-header h2{color:#000;font-size:1.5em;font-weight:600;margin:0}.btn-logout{background:#fff;color:#000;border:2px solid #000000;padding:10px 20px;font-size:.9em}.btn-logout:hover{background:#000;color:#fff}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:20px;margin-top:20px}.stat-card{background:#fff;padding:20px;border-radius:12px;border:2px solid #e0e0e0;text-align:center}.stat-value{font-size:2em;font-weight:700;color:#000;margin-bottom:8px}.stat-value.correct{color:#388e3c}.stat-value.wrong{color:#d32f2f}.stat-value.no-answer{color:#f57f17}.stat-label{color:#666;font-size:.9em;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.no-stats{text-align:center;padding:60px 20px;color:#666}.no-stats p:first-child{font-size:1.5em;font-weight:600;color:#000;margin-bottom:10px}.no-stats-hint{font-size:1em;color:#999}.quiz-toggle{text-align:center;margin:30px 0}.quiz-toggle .btn{min-width:200px}.quiz-history{margin-top:40px}.quiz-history h3{font-size:1.3em;font-weight:600;margin-bottom:20px;color:#000}.history-list{display:flex;flex-direction:column;gap:12px}.history-item{background:#fff;border:1px solid #ddd;border-radius:8px;padding:15px 20px;transition:border-color .2s}.history-item:hover{border-color:#000}.history-quiz-name{font-size:1.1em;font-weight:600;color:#000;margin-bottom:8px}.history-details{display:flex;gap:20px;font-size:.9em;color:#666;flex-wrap:wrap}.history-score{font-weight:500;color:#000}.history-attempt{color:#666}.history-date{color:#999}.admin-dashboard{max-width:1200px;margin:0 auto;padding:20px;background:#fff;border:2px solid #000;border-radius:16px}.users-table-container{margin-top:30px}.users-table-container h3{font-size:1.3em;font-weight:600;margin-bottom:20px;color:#000}.users-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid #ddd;border-radius:8px;overflow:hidden}.users-table thead{background:#f5f5f5;border-bottom:2px solid #000}.users-table th{padding:15px;text-align:left;font-weight:600;color:#000;text-transform:uppercase;font-size:.85em;letter-spacing:.5px}.users-table td{padding:12px 15px;border-bottom:1px solid #eee;color:#333}.users-table tbody tr:hover{background:#f9f9f9}.users-table tbody tr:last-child td{border-bottom:none}.username-cell{font-weight:500;color:#000}.role-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:.85em;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.role-badge.admin{background:#000;color:#fff}.role-badge.user{background:#f0f0f0;color:#666}.quiz-count{font-weight:600;color:#2e7d32}.last-login{font-size:.9em;color:#666}.ip-cell{font-family:monospace;font-size:.85em;color:#333;background:#f5f5f5;padding:4px 8px;border-radius:4px}.location-cell{font-size:.85em;color:#555;max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(max-width:768px){.auth-box{padding:30px 20px}.dashboard-header{flex-direction:column;gap:15px;text-align:center}.stats-grid{grid-template-columns:repeat(2,1fr)}.users-table{font-size:.85em}.users-table th,.users-table td{padding:8px 10px}}.upload-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.upload-header h2{margin:0}.format-help-link{background:none;border:none;color:#000;font-weight:600;cursor:pointer;font-size:.9em;display:flex;align-items:center;gap:5px;padding:8px 12px;border-radius:6px;transition:all .3s}.format-help-link:hover{background:#f5f5f5}.help-icon{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;background:#000;color:#fff;border-radius:50%;font-size:.85em;font-weight:700}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:16px;border:2px solid #000000;max-width:700px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:25px;border-bottom:2px solid #e0e0e0}.modal-header h3{margin:0;color:#000;font-size:1.5em;font-weight:700}.modal-close{background:none;border:none;font-size:2em;color:#000;cursor:pointer;padding:0;width:35px;height:35px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .3s}.modal-close:hover{background:#f5f5f5}.modal-body{padding:25px}.modal-footer{padding:20px 25px;border-top:2px solid #e0e0e0;display:flex;justify-content:flex-end}.format-intro{color:#000;margin-bottom:20px;font-size:1.05em}.format-example{background:#f5f5f5;border:2px solid #e0e0e0;border-radius:8px;padding:20px;margin-bottom:25px}.format-example h4{margin:0 0 15px;color:#000;font-size:1.1em}.format-example pre{background:#fff;border:1px solid #e0e0e0;border-radius:6px;padding:15px;overflow-x:auto;font-family:Courier New,monospace;font-size:.9em;line-height:1.6;color:#000;margin:0}.format-rules,.format-tips{margin-bottom:20px}.format-rules h4,.format-tips h4{color:#000;margin-bottom:12px;font-size:1.1em}.format-rules ul,.format-tips ul{padding-left:20px;margin:0}.format-rules li,.format-tips li{color:#000;margin-bottom:8px;line-height:1.6}.format-rules strong,.format-tips strong{color:#000;font-weight:600}@media(max-width:768px){.modal-content{max-height:95vh}.upload-header{flex-direction:column;align-items:flex-start;gap:10px}.format-help-link{align-self:flex-start}}
