*{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}.app{min-height:100vh;display:flex;flex-direction:column}.header{background-color:#2c3e50;color:#fff;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0000001a}.header h1{font-size:1.5rem}.nav-links{display:flex;gap:1rem}.nav-links a{color:#fff;text-decoration:none;padding:.5rem 1rem;border-radius:4px;transition:background-color .2s}.nav-links a:hover{background-color:#34495e}.main-content{flex:1;padding:2rem;max-width:1200px;margin:0 auto;width:100%}.login-container,.register-container,.learning-container,.testing-container,.test-history-container{background-color:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 10px #0000001a}.login-container h2,.register-container h2,.learning-container h2,.testing-container h2,.test-history-container h2{margin-bottom:1.5rem;color:#333}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#666;font-weight:500}.form-group input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#3498db}.login-button,.register-button,.start-test-button,.submit-test-button,.learned-button{width:100%;padding:.75rem;background-color:#3498db;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:background-color .2s}.login-button:hover,.register-button:hover,.start-test-button:hover,.submit-test-button:hover,.learned-button:hover{background-color:#2980b9}.register-link,.login-link{text-align:center;margin-top:1.5rem;color:#666}.register-link a,.login-link a{color:#3498db;text-decoration:none}.error-message{background-color:#e74c3c;color:#fff;padding:1rem;border-radius:4px;margin-bottom:1rem}.success-message{background-color:#27ae60;color:#fff;padding:1rem;border-radius:4px;margin-bottom:1rem}.characters-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;margin-top:1.5rem}.character-card{background-color:#f8f9fa;padding:1.5rem;border-radius:8px;border:1px solid #e9ecef;transition:transform .2s}.character-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.character-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.character{font-size:2rem;font-weight:700;color:#333}.character-meanings{margin-top:1rem}.meaning-item{margin-bottom:1rem;padding:1rem;background-color:#fff;border-radius:4px;border-left:3px solid #3498db}.pinyin{font-size:1.2rem;color:#3498db;margin-bottom:.5rem}.tone{font-size:.8rem;color:#666}.part-of-speech{font-size:.8rem;color:#95a5a6;margin-bottom:.5rem}.meaning{color:#333;line-height:1.6}.error-info{color:#e74c3c;margin-top:.5rem;font-size:.9rem}.correct-words,.correct-examples{margin-top:.5rem;font-size:.9rem;color:#666}.correct-examples ul{margin:.5rem 0 0 1.5rem;padding:0}.correct-examples li{margin-bottom:.3rem;line-height:1.4}.testing-container{max-width:800px;margin:0 auto}.question-card{background-color:#f8f9fa;padding:1.5rem;border-radius:8px;margin-bottom:1.5rem;border:1px solid #e9ecef}.question-content{font-size:1.2rem;color:#333;margin-bottom:1rem}.options-list{display:flex;flex-direction:column;gap:.5rem}.option-item{padding:.75rem 1rem;border:1px solid #ddd;border-radius:4px;cursor:pointer;transition:background-color .2s}.option-item:hover{background-color:#e9ecef}.option-item.selected{background-color:#3498db;color:#fff;border-color:#3498db}.option-item.correct{background-color:#27ae60;color:#fff;border-color:#27ae60}.option-item.incorrect{background-color:#e74c3c;color:#fff;border-color:#e74c3c}.submit-test-button{margin-top:2rem}.test-result{text-align:center;padding:2rem}.test-result h3{font-size:1.5rem;color:#333;margin-bottom:1rem}.score{font-size:3rem;font-weight:700;color:#3498db;margin-bottom:2rem}.restart-button{padding:.75rem 2rem;background-color:#27ae60;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:background-color .2s}.restart-button:hover{background-color:#219a52}.test-history-list{margin-top:1.5rem}.test-record{background-color:#f8f9fa;padding:1rem 1.5rem;border-radius:8px;margin-bottom:1rem;border-left:3px solid #3498db;display:flex;justify-content:space-between;align-items:center}.test-record:hover{background-color:#e9ecef}.test-record-info{display:flex;align-items:center;gap:1rem}.test-record-date{color:#666;font-size:.9rem}.test-record-score{font-weight:700;color:#3498db;font-size:1.2rem}.loading{text-align:center;padding:2rem;font-size:1.2rem;color:#666}@media(max-width:768px){.main-content{padding:1rem}.login-container,.register-container,.learning-container,.testing-container,.test-history-container{padding:1.5rem}.characters-grid{grid-template-columns:1fr}.header{padding:1rem}.header h1{font-size:1.2rem}.nav-links{gap:.5rem}.nav-links a{padding:.5rem .75rem;font-size:.9rem}}.learning-content{display:flex;flex-direction:column;align-items:center}.learning-controls{display:flex;flex-direction:row;justify-content:center;align-items:center;gap:2rem;margin-top:2rem}.action-button{padding:.75rem 2rem;background-color:#3498db;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:background-color .2s;min-width:150px}.action-button:hover{background-color:#2980b9}.action-button:disabled{background-color:#bdc3c7;cursor:not-allowed}.learning-progress{margin-top:1rem;color:#666;font-size:.9rem}.admin-page{display:flex;flex-direction:column;min-height:100vh}.admin-container{display:flex;flex:1;margin-top:80px}.admin-sidebar{width:200px;background-color:#f5f5f5;padding:20px;border-right:1px solid #e0e0e0}.admin-sidebar h2{font-size:1.5rem;margin-bottom:20px;color:#333}.admin-sidebar nav{display:flex;flex-direction:column}.sidebar-item{padding:12px 16px;margin-bottom:8px;border-radius:4px;color:#555;text-decoration:none;font-weight:500;transition:background-color .2s ease}.sidebar-item:hover{background-color:#e0e0e0}.sidebar-item.active{background-color:#2196f3;color:#fff}.admin-content{flex:1;padding:20px;background-color:#fafafa}.loading{display:flex;justify-content:center;align-items:center;height:200px;font-size:1.2rem;color:#666}.characters-management,.users-management,.statistics{background-color:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 4px #0000001a}.management-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.search-input{padding:8px 16px;border:1px solid #ddd;border-radius:4px;font-size:14px;width:200px}.create-button{padding:8px 16px;background-color:#2196f3;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s ease}.create-button:hover{background-color:#1976d2}.data-table{width:100%;border-collapse:collapse;margin-bottom:20px}.data-table th,.data-table td{padding:12px 16px;text-align:left;border-bottom:1px solid #e0e0e0}.data-table th{background-color:#f5f5f5;font-weight:600;color:#333}.data-table tr:hover{background-color:#f9f9f9}.edit-button{padding:6px 12px;background-color:#ffc107;color:#333;border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;margin-right:8px;transition:background-color .2s ease}.edit-button:hover{background-color:#ffb300}.delete-button{padding:6px 12px;background-color:#f44336;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;transition:background-color .2s ease}.delete-button:hover{background-color:#d32f2f}.pagination{display:flex;justify-content:center;align-items:center;gap:16px}.pagination button{padding:8px 16px;background-color:#f5f5f5;color:#333;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s ease}.pagination button:hover:not(:disabled){background-color:#e0e0e0}.pagination button:disabled{opacity:.5;cursor:not-allowed}.pagination span{font-size:14px;color:#666}.chart-container{width:100%;height:300px;margin-top:20px}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background-color:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 10px #0003;width:90%;max-width:500px;max-height:80vh;overflow-y:auto}.modal-content h4{margin-top:0;margin-bottom:1.5rem;color:#333}.modal-content .form-group{margin-bottom:1rem}.modal-content label{display:block;margin-bottom:.5rem;color:#666;font-weight:500}.modal-content input,.modal-content select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;transition:border-color .2s}.modal-content input:focus,.modal-content select:focus{outline:none;border-color:#3498db}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1.5rem}.save-button,.cancel-button{padding:.75rem 1.5rem;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.save-button{background-color:#27ae60;color:#fff}.save-button:hover:not(:disabled){background-color:#219a52}.save-button:disabled{background-color:#bdc3c7;cursor:not-allowed}.cancel-button{background-color:#95a5a6;color:#fff}.cancel-button:hover{background-color:#7f8c8d}.badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:.8rem;font-weight:500;color:#fff;text-transform:uppercase;letter-spacing:.5px;transition:all .2s ease}.badge-normal{background-color:#95a5a6}.badge-polyphonic{background-color:#3498db}.badge-easy-read-wrong{background-color:#e74c3c}.badge-easy-write-wrong{background-color:#f39c12}.badge-easy-use-wrong{background-color:#9b59b6}.badge-ancient{background-color:#2ecc71}.meanings-section{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e0e0e0}.meanings-section h5{margin-bottom:1rem;color:#333;font-size:1.1rem}.meaning-form{background-color:#f8f9fa;padding:1.5rem;border-radius:8px;margin-bottom:1rem;border:1px solid #e9ecef}.meaning-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.meaning-header span{font-weight:600;color:#333;font-size:1rem}.remove-button{padding:4px 8px;background-color:#f44336;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.8rem;transition:background-color .2s ease}.remove-button:hover{background-color:#d32f2f}.form-row{display:flex;gap:1rem}.form-row .form-group{flex:1}.form-group textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;resize:vertical;min-height:80px;transition:border-color .2s}.form-group textarea:focus{outline:none;border-color:#3498db}.add-meaning-button{width:100%;padding:.75rem;background-color:#2196f3;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:500;transition:background-color .2s ease}.add-meaning-button:hover{background-color:#1976d2}.character-form-page{background-color:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 10px #0000001a}.character-form-page h3{margin-top:0;margin-bottom:1.5rem;color:#333}.error-message{background-color:#f44336;color:#fff;padding:1rem;border-radius:4px;margin-bottom:1.5rem;font-size:.9rem;line-height:1.4}.error-message:hover{background-color:#d32f2f}.form-container{max-width:600px;margin:0 auto}.form-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem}.smart-fill-button{padding:.5rem 1rem;background-color:#ff9800;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:500;transition:background-color .2s ease}.smart-fill-button:hover{background-color:#fb8c00}.smart-fill-button:disabled{background-color:#bdc3c7;cursor:not-allowed}.form-header{margin-bottom:1rem;display:flex;justify-content:flex-end}.search-container{display:flex;gap:.5rem}.loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.loading-content{background-color:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 10px #0003;display:flex;flex-direction:column;align-items:center}.loading-text{font-size:1.2rem;color:#333;margin-bottom:1rem}.loading-dots:after{content:"";animation:loadingDots 1.5s infinite}@keyframes loadingDots{0%,20%{content:"."}40%{content:".."}60%,to{content:"..."}}.search-button{padding:8px 16px;background-color:#2196f3;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s ease}.search-button:hover{background-color:#1976d2}.dynamic-inputs{margin-top:.5rem}.dynamic-input-row{display:flex;align-items:center;margin-bottom:.5rem;gap:.5rem}.dynamic-input-row input{flex:1;padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.add-input-button{padding:.5rem 1rem;background-color:#2196f3;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background-color .2s ease}.add-input-button:hover{background-color:#1976d2}.remove-input-button{padding:.25rem .5rem;background-color:#f44336;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.8rem;transition:background-color .2s ease}.remove-input-button:hover{background-color:#d32f2f}@media(max-width:768px){.admin-container{flex-direction:column}.admin-sidebar{width:100%;border-right:none;border-bottom:1px solid #e0e0e0}.admin-content{padding:10px}.management-header{flex-direction:column;align-items:flex-start;gap:10px}.search-input{width:100%}.data-table{font-size:12px}.data-table th,.data-table td{padding:8px 12px}.modal-content{width:95%;padding:1.5rem}.form-row{flex-direction:column}.meaning-form{padding:1rem}}
