*{box-sizing:border-box;margin:0;padding:0}:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}button{font-family:inherit}.certificate-modal{position:fixed;inset:0;background:#000c;display:flex;align-items:flex-start;justify-content:center;z-index:2000;padding:20px;overflow-y:auto}.certificate-modal-content{width:100%;max-width:1000px;display:flex;flex-direction:column;align-items:center;max-height:calc(100vh - 40px);overflow:hidden}.certificate-actions{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap;justify-content:center}.download-button,.print-button,.close-button{padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s}.download-button{background:#27ae60;color:#fff}.download-button:hover{background:#229954;transform:translateY(-2px)}.print-button{background:#3498db;color:#fff}.print-button:hover{background:#2980b9;transform:translateY(-2px)}.close-button{background:#e74c3c;color:#fff}.close-button:hover{background:#c0392b;transform:translateY(-2px)}.certificate-container{background:#fff;padding:20px;border-radius:12px;box-shadow:0 20px 60px #0000004d;width:100%;max-height:calc(100vh - 140px);overflow:auto}.certificate{background:linear-gradient(135deg,#fff5e6,#fff);border:8px solid #d4af37;border-radius:12px;padding:60px 40px;min-height:0;display:flex;flex-direction:column;justify-content:space-between;position:relative}.certificate:before{content:"";position:absolute;inset:20px;border:2px solid rgba(212,175,55,.3);border-radius:8px;pointer-events:none}.certificate-header{text-align:center;margin-bottom:40px}.certificate-header h1{margin:0;color:#8b6914;font-size:42px;font-weight:700;letter-spacing:4px;text-shadow:2px 2px 4px rgba(0,0,0,.1)}.certificate-body{flex:1;display:flex;flex-direction:column;align-items:center;text-align:center}.certificate-text{font-size:18px;color:#555;margin:10px 0;line-height:1.6}.student-name{font-size:36px;font-weight:700;color:#8b6914;margin:20px 0;padding:10px 20px;border-bottom:3px solid #d4af37;display:inline-block}.grades-section{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin:30px 0;width:100%;max-width:600px}.grade-item{background:#d4af371a;padding:15px;border-radius:8px;display:flex;justify-content:space-between;align-items:center}.grade-label{font-size:16px;color:#555;font-weight:500}.grade-value{font-size:24px;font-weight:700;color:#8b6914}.final-grade{margin-top:30px;padding:20px;background:#d4af3726;border-radius:8px;width:100%;max-width:500px}.average-text{font-size:20px;color:#555;margin:10px 0}.average-value{font-size:28px;font-weight:700;color:#8b6914}.grade-text{font-size:22px;color:#555;margin:10px 0}.grade-value-big{font-size:32px;font-weight:700;color:#d4af37}.certificate-footer{margin-top:40px;text-align:center}.footer-content{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;width:100%}@media(max-width:480px){.footer-content{flex-direction:column}}.date-section{color:#666;font-size:16px;flex:1}.certificate-qr{display:flex;flex-direction:column;align-items:center;padding:8px;background:#fff;border-radius:8px}.certificate-qr svg{display:block}.qr-label{margin:6px 0 0;font-size:11px;color:#666}@media print{.certificate-modal{background:#fff}.certificate-actions{display:none}.certificate-container{box-shadow:none;padding:0;max-height:none;overflow:visible}.certificate{border:none;padding:40px}}@media(max-width:768px){.certificate-modal{padding:12px}.certificate-modal-content{max-height:calc(100vh - 24px)}.certificate-container{padding:12px;max-height:calc(100vh - 150px)}.certificate{padding:40px 20px}.certificate-header h1{font-size:28px}.student-name{font-size:24px}.grades-section{grid-template-columns:1fr}}@media(max-width:420px){.certificate-actions{width:100%}.download-button,.print-button,.close-button{width:100%;padding:10px 12px;font-size:14px}.certificate-header h1{font-size:22px;letter-spacing:2px}.certificate-text{font-size:15px}}.verification-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.verification-card{background:#fff;border-radius:12px;padding:40px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:400px}.verification-card h1{margin:0 0 10px;color:#333;font-size:28px;text-align:center}.verification-card h2{margin:0 0 12px;color:#666;font-size:20px;font-weight:400;text-align:center}.verification-subtitle{margin:0 0 30px;color:#888;font-size:14px;text-align:center;line-height:1.5}.verification-card .form-group{margin-bottom:20px}.verification-card .form-group label{display:block;margin-bottom:8px;color:#333;font-weight:500}.verification-card .form-group input{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:border-color .3s;box-sizing:border-box}.verification-card .form-group input:focus{outline:none;border-color:#667eea}.verification-card .error-message{background-color:#fee;color:#c33;padding:12px;border-radius:8px;margin-bottom:20px;text-align:center;border:1px solid #fcc}.verify-button{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.verify-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.verify-button:active{transform:translateY(0)}@media(max-width:480px){.verification-container{padding:14px}.verification-card{padding:24px 18px}.verification-card h1{font-size:22px}.verification-card h2{font-size:16px;margin-bottom:8px}.verification-subtitle{font-size:13px;margin-bottom:24px}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card{background:#fff;border-radius:12px;padding:40px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:400px}.login-card h1{margin:0 0 10px;color:#333;font-size:28px;text-align:center}.login-card h2{margin:0 0 30px;color:#666;font-size:20px;font-weight:400;text-align:center}.error-message{background-color:#fee;color:#c33;padding:12px;border-radius:8px;margin-bottom:20px;text-align:center;border:1px solid #fcc}.login-button{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.login-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.login-button:active{transform:translateY(0)}.login-info{margin-top:20px;padding-top:20px;border-top:1px solid #e0e0e0;text-align:center;color:#999;font-size:14px}.login-info .back-link{color:#667eea;text-decoration:none;font-weight:500}.login-info .back-link:hover{color:#764ba2;text-decoration:underline}@media(max-width:480px){.login-container{padding:14px}.login-card{padding:24px 18px}.login-card h1{font-size:22px}.login-card h2{font-size:16px;margin-bottom:20px}}.student-form-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.student-form-card{background:#fff;border-radius:12px;padding:30px;max-width:700px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.student-form-card h2{margin:0 0 25px;color:#333;font-size:24px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#333;font-weight:500}.form-group input{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:border-color .3s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea}.form-group input.error{border-color:#e74c3c}.error-text{display:block;color:#e74c3c;font-size:14px;margin-top:5px}.grades-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:20px}@media(max-width:600px){.grades-grid{grid-template-columns:1fr}}.form-actions{display:flex;gap:15px;justify-content:flex-end;margin-top:30px;padding-top:20px;border-top:1px solid #e0e0e0}.cancel-button,.save-button{padding:12px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s;border:none}.cancel-button{background:#e0e0e0;color:#333}.cancel-button:hover{background:#d0d0d0}.save-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.save-button:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea4d}@media(max-width:480px){.student-form-overlay{padding:12px}.student-form-card{padding:18px}.student-form-card h2{font-size:20px;margin-bottom:16px}.form-actions{flex-direction:column;justify-content:stretch}.cancel-button,.save-button{width:100%}}.student-list{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.student-list table{width:100%;border-collapse:collapse}.student-list thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.student-list th{padding:15px;text-align:left;font-weight:600;font-size:14px;text-transform:uppercase;letter-spacing:.5px}.student-list tbody tr{border-bottom:1px solid #e0e0e0;transition:background-color .2s}.student-list tbody tr:hover{background-color:#f9f9f9}.student-list tbody tr:last-child{border-bottom:none}.student-list td{padding:15px;color:#333}.action-buttons{display:flex;gap:8px;flex-wrap:wrap}.view-button,.edit-button,.delete-button{padding:6px 12px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.view-button{background:#3498db;color:#fff}.view-button:hover{background:#2980b9;transform:translateY(-1px)}.edit-button{background:#f39c12;color:#fff}.edit-button:hover{background:#e67e22;transform:translateY(-1px)}.delete-button{background:#e74c3c;color:#fff}.delete-button:hover{background:#c0392b;transform:translateY(-1px)}.empty-state{background:#fff;border-radius:12px;padding:60px 20px;text-align:center;box-shadow:0 2px 8px #0000001a}.empty-state p{color:#999;font-size:18px;margin:0}@media(max-width:768px){.student-list{overflow-x:auto}.student-list table{min-width:800px}.action-buttons{flex-direction:column}.view-button,.edit-button,.delete-button{width:100%}}@media(max-width:640px){.student-list{overflow:visible;background:transparent;box-shadow:none}.student-list table{min-width:0;width:100%;border-collapse:separate;border-spacing:0 12px}.student-list thead{display:none}.student-list tbody tr{display:block;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;border-bottom:none;overflow:hidden}.student-list td{display:flex;justify-content:space-between;gap:12px;padding:12px 14px;border-bottom:1px solid #f0f0f0}.student-list td:last-child{border-bottom:none}.student-list td:before{content:attr(data-label);font-weight:700;color:#666;text-transform:none;letter-spacing:0}.action-buttons{width:100%;justify-content:flex-end;flex-direction:row}.view-button,.edit-button,.delete-button{width:auto;padding:10px 12px}}.success-notification{position:fixed;top:20px;right:20px;z-index:3000;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.success-notification-content{background:linear-gradient(135deg,#27ae60,#229954);color:#fff;padding:16px 20px;border-radius:8px;box-shadow:0 4px 12px #00000026;display:flex;align-items:center;gap:12px;min-width:300px;max-width:400px}.success-icon{background:#fff3;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;flex-shrink:0}.success-message{flex:1;font-size:16px;font-weight:500}.success-close{background:transparent;border:none;color:#fff;font-size:24px;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s;flex-shrink:0}.success-close:hover{background:#fff3}@media(max-width:480px){.success-notification{top:10px;right:10px;left:10px}.success-notification-content{min-width:0;width:100%;padding:14px 16px}.success-message{font-size:14px}}.admin-portal{min-height:100vh;background:#f5f5f5}.admin-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px 40px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 10px #0000001a}.admin-header h1{margin:0;font-size:24px}.logout-button{background:#fff3;color:#fff;border:2px solid white;padding:10px 20px;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s}.logout-button:hover{background:#fff;color:#667eea}.admin-main{max-width:1400px;margin:0 auto;padding:30px 20px}.admin-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;background:#fff;padding:20px 30px;border-radius:12px;box-shadow:0 2px 8px #0000001a}.admin-toolbar h2{margin:0;color:#333;font-size:22px}.add-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.add-button:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea4d}.students-loading{text-align:center;padding:40px;color:#666;font-size:16px}@media(max-width:768px){.admin-header{padding:16px;flex-direction:column;align-items:stretch;gap:12px}.admin-header h1{font-size:20px;line-height:1.2}.logout-button{width:100%}.admin-main{padding:20px 12px}.admin-toolbar{padding:16px;flex-direction:column;align-items:stretch;gap:12px}.add-button{width:100%}}@media(max-width:420px){.admin-header h1{font-size:18px}}.App{width:100%;min-height:100vh}.auth-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.auth-loading-spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
