:root{--primary-dark: #074f57;--primary-blue: #077187;--primary-green: #74a57f;--light-green: #9ece9a;--light-beige: #e4c5af;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color:#333;background-color:var(--primary-dark);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-height:100vh;background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary-blue) 100%);color:#fff;font-family:inherit}#root{min-height:100vh;display:flex;flex-direction:column}a{font-weight:500;color:var(--light-green);text-decoration:none;transition:color .3s ease}a:hover{color:var(--light-beige)}h1{font-size:2.5em;line-height:1.2;margin-bottom:1rem;color:var(--light-beige);font-weight:600}h2{font-size:1.8em;margin-bottom:.8rem;color:var(--light-green);font-weight:500}h3{font-size:1.4em;margin-bottom:.6rem;color:var(--light-beige);font-weight:500}button{border-radius:8px;border:none;padding:.8rem 1.5rem;font-size:1rem;font-weight:500;font-family:inherit;background-color:var(--primary-blue);color:#fff;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 4px #0000001a}button:hover{background-color:var(--primary-green);transform:translateY(-2px);box-shadow:0 4px 8px #0003}button:active{transform:translateY(0)}button:disabled{background-color:#ccc;cursor:not-allowed;transform:none}.btn-success{background-color:var(--primary-green)}.btn-success:hover{background-color:var(--light-green)}.btn-secondary{background-color:var(--light-beige);color:var(--primary-dark)}.btn-secondary:hover{background-color:#d4b59e}input,select,textarea{border-radius:8px;border:2px solid var(--light-beige);padding:.8rem 1rem;font-size:1rem;font-family:inherit;background-color:#fff;color:var(--primary-dark);transition:all .3s ease;width:100%;max-width:300px}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #74a57f33}input::placeholder{color:#999}.card{background-color:#fffffff2;border-radius:12px;padding:2rem;margin:1rem;box-shadow:0 8px 32px #0000001a;color:var(--primary-dark);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}table{width:100%;border-collapse:collapse;margin:1rem 0;background-color:#fff;border-radius:8px;overflow:hidden;box-shadow:0 4px 6px #0000001a}th,td{padding:1rem;text-align:left;border-bottom:1px solid #e0e0e0}th{background-color:var(--primary-dark);color:#fff;font-weight:600}tr:hover{background-color:var(--light-beige)}.loading,.error{text-align:center;padding:2rem;font-size:1.2rem}.loading{color:var(--light-green)}.error{color:#ff6b6b}@media (max-width: 768px){.card{margin:.5rem;padding:1.5rem}h1{font-size:2rem}button{padding:.7rem 1.2rem;font-size:.9rem}input,select,textarea{padding:.7rem .8rem;font-size:.9rem}}.app{min-height:100vh;display:flex;flex-direction:column}.navbar{background-color:var(--primary-dark);padding:.7rem 2rem;box-shadow:0 4px 6px #0000001a;position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between}.navbar-left,.navbar-center,.navbar-right{flex:1;display:flex;align-items:center}.navbar-left{justify-content:flex-start}.navbar-center{justify-content:center}.navbar-right{justify-content:flex-end;gap:2rem}.navbar-brand{font-size:1.8rem;font-weight:700;color:var(--light-beige);text-decoration:none;display:flex;align-items:center;gap:.5rem}.navbar-brand:hover{color:var(--light-green)}.admin-navbar-title{text-align:center}.admin-navbar-title h1{color:var(--light-beige);margin:0;font-size:1.8rem;font-weight:700}.admin-navbar-title p{color:var(--light-green);margin:0;font-size:1rem}.admin-menu-container{position:relative}.admin-menu-toggle{background:none;border:none;cursor:pointer;font-size:1rem}.admin-submenu{position:absolute;top:100%;right:-1rem;background-color:#fffffffa;border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:180px;z-index:1000;margin-top:.5rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.submenu-item{display:block;width:100%;padding:.8rem 1rem;background:none;border:none;text-align:left;cursor:pointer;color:var(--primary-dark);font-size:.9rem;transition:all .3s ease;border-radius:4px}.submenu-item:hover{background-color:var(--light-beige);color:var(--primary-blue)}.submenu-item.active{background-color:var(--primary-blue);color:#fff}.submenu-item:first-child{border-radius:8px 8px 4px 4px}.submenu-item:last-child{border-radius:4px 4px 8px 8px}.logout-nav-button{background:none;border:none;cursor:pointer;font-size:1rem}.nav-link{color:var(--light-beige);text-decoration:none;padding:.5rem 1rem;border-radius:6px;transition:all .3s ease;font-weight:500}.nav-link:hover{background-color:var(--primary-blue);color:#fff}.nav-link.active{background-color:var(--primary-green);color:#fff}.main-content{flex:1;padding:2rem;max-width:1200px;margin:0 auto;width:100%}.page-container{max-width:800px;margin:0 auto;padding:2rem 0}.homepage{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:70vh;text-align:center}.homepage-card{background-color:#fffffff2;border-radius:20px;padding:3rem;box-shadow:0 20px 40px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);max-width:500px;width:100%}.homepage-title{color:var(--primary-dark);margin-bottom:2rem;font-size:2.5rem;font-weight:700}.input-group{margin-bottom:2rem}.input-group label{display:block;margin-bottom:.5rem;color:var(--primary-dark);font-weight:500}.input-group input{width:100%;max-width:none;margin-bottom:1rem}.search-dropdown{position:absolute;top:100%;left:0;right:0;background-color:#fff;border:1px solid #ddd;border-top:none;border-radius:0 0 8px 8px;box-shadow:0 4px 12px #00000026;z-index:1000;max-height:300px;overflow-y:auto}.search-item{padding:8px 16px;cursor:pointer;border-bottom:1px solid #f0f0f0;transition:background-color .2s ease}.search-item:last-child{border-bottom:none}.search-item:hover{background-color:var(--light-green);color:#fff}.search-item.loading{text-align:center;color:var(--primary-blue);cursor:default;font-style:italic}.search-item.loading:hover{background-color:transparent;color:var(--primary-blue)}.search-dropdown .student-info{display:flex!important;flex-direction:row!important;align-items:center!important;gap:12px!important;width:100%!important}.search-dropdown .student-info .student-id{font-weight:600!important;color:var(--primary-blue)!important;font-size:.9rem!important;min-width:50px!important;flex-shrink:0!important;display:inline!important}.search-dropdown .student-info .student-name{font-weight:500!important;color:var(--primary-dark)!important;flex:1!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important;display:inline!important}.search-dropdown .student-info .student-class{font-size:.85rem!important;color:var(--primary-green)!important;font-weight:400!important;flex-shrink:0!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important;display:inline!important}.search-button{background-color:var(--primary-blue);color:#fff;padding:1rem 2rem;font-size:1.1rem;border:none;border-radius:10px;cursor:pointer;transition:all .3s ease;width:100%;max-width:200px}.search-button:hover{background-color:var(--primary-green);transform:translateY(-2px)}.student-info{display:flex;flex-direction:column;align-items:center;gap:2rem}.student-card{background-color:#fffffff2;border-radius:16px;padding:2.5rem;box-shadow:0 12px 24px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);max-width:600px;width:100%}.student-card h1{color:var(--primary-dark);text-align:center;margin-bottom:2rem}.student-details{display:grid;gap:1.5rem;margin-bottom:2rem}.detail-item{display:flex;align-items:center;gap:1rem;padding:1rem;background-color:var(--light-beige);border-radius:8px;color:var(--primary-dark)}.detail-label{font-weight:600;min-width:80px}.detail-value{font-size:1.1rem}.confirm-button{background-color:var(--primary-green);color:#fff;padding:1rem 2rem;font-size:1.1rem;border:none;border-radius:10px;cursor:pointer;transition:all .3s ease;width:100%}.confirm-button:hover{background-color:var(--light-green);transform:translateY(-2px)}.admin-dashboard{padding:1.5rem;display:flex;flex-direction:column;min-height:calc(100vh - 120px)}.filters-section{background-color:#fffffff2;border-radius:10px;padding:1rem;margin-bottom:1rem;color:var(--primary-dark)}.filters-title{color:var(--primary-dark);margin-bottom:.8rem;font-size:1.1rem}.filters-container{display:flex;gap:1.5rem;align-items:flex-end;flex-wrap:wrap}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;flex:1;min-width:0}.filter-group{display:flex;flex-direction:column;gap:.3rem}.filter-group label{font-weight:500;color:var(--primary-dark);font-size:.9rem}.filter-group select,.filter-group input{max-width:none;padding:.6rem .8rem;font-size:.9rem}.filter-actions{display:flex;gap:.8rem;align-items:center;flex-shrink:0;margin-bottom:.2rem;justify-content:flex-end;min-height:2.5rem}.btn-filter{background-color:var(--primary-blue);color:#fff;padding:.6rem 1.2rem;border:none;border-radius:6px;cursor:pointer;font-weight:500;font-size:.9rem;transition:all .3s ease;white-space:nowrap}.btn-filter:hover{background-color:var(--primary-green)}.btn-reset{background-color:var(--light-beige);color:var(--primary-dark);padding:.6rem 1.2rem;border:none;border-radius:6px;cursor:pointer;font-weight:500;font-size:.9rem;transition:all .3s ease;white-space:nowrap}.btn-reset:hover{background-color:#d4b59e}.records-section{background-color:#fffffff2;border-radius:12px;padding:1.2rem;color:var(--primary-dark);flex:1}.records-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:1rem}.records-title{color:var(--primary-dark);margin:0;font-size:1.4rem;font-weight:600;flex:1}.records-actions{display:flex;gap:.8rem;align-items:center}.records-actions .btn-filter,.records-actions .btn-reset{padding:.6rem 1rem;font-size:.85rem;white-space:nowrap}.records-table{width:100%;border-collapse:collapse;margin-top:.5rem;font-size:.95rem}.records-table th{background-color:var(--primary-dark);color:#fff;padding:.8rem;text-align:left;font-weight:600;font-size:.9rem}.records-table td{padding:.8rem;border-bottom:1px solid #e0e0e0}.records-table tr:hover{background-color:var(--light-beige)}.status-loading{text-align:center;padding:2rem;color:var(--light-green);font-size:1.1rem}.status-error{text-align:center;padding:2rem;color:#ff6b6b;font-size:1.1rem}.status-empty{text-align:center;padding:2rem;color:var(--primary-dark);font-size:1.1rem}@media (max-width: 768px){.navbar{padding:1rem}.navbar-nav{gap:1rem}.main-content{padding:1rem}.homepage-card{padding:2rem;margin:1rem}.homepage-title{font-size:2rem}.student-card{padding:1.5rem;margin:1rem}.detail-item{flex-direction:column;align-items:flex-start;gap:.5rem}.admin-dashboard{padding:1rem}.admin-header h1{font-size:1.8rem}.filters-section{padding:1rem}.filters-container{flex-direction:column;gap:1rem;align-items:stretch}.filters-grid{grid-template-columns:1fr;gap:.8rem}.filter-actions{justify-content:center;gap:.5rem;min-height:2rem}.records-section{padding:1rem}.records-header{flex-direction:column;align-items:flex-start;gap:1rem}.records-actions{width:100%;justify-content:flex-start}.records-actions .btn-filter,.records-actions .btn-reset{padding:.5rem .8rem;font-size:.8rem}.records-table{font-size:.8rem}.records-table th,.records-table td{padding:.5rem}.records-table th:last-child,.records-table td:last-child{width:90px}}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background-color:#fffffff2;border-radius:12px;padding:1.5rem;max-width:450px;width:100%;max-height:90vh;overflow-y:auto;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);box-shadow:0 20px 40px #0000001a}.modal-title{color:var(--primary-dark);margin-bottom:1.5rem;font-size:1.3rem;font-weight:600;text-align:center}.modal-form{display:flex;flex-direction:column;gap:1rem}.modal-actions{display:flex;gap:1rem;justify-content:center;margin-top:1.5rem}.modal-actions button{padding:.8rem 1.5rem;font-size:.9rem;border-radius:8px;font-weight:500}.records-table input[type=checkbox]{transform:scale(1.2);margin:0;cursor:pointer}.records-table th:first-child,.records-table td:first-child{text-align:center;width:50px}.records-table th:last-child,.records-table td:last-child{text-align:center;width:100px}.action-btn{padding:.3rem .6rem;font-size:.8rem;border:none;border-radius:4px;cursor:pointer;transition:all .3s ease}.action-btn:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0003}.action-btn.edit{background-color:var(--primary-green);color:#fff}.action-btn.edit:hover{background-color:var(--light-green)}.text-center{text-align:center}.text-success{color:var(--primary-green)}.text-warning{color:#ffa726}.text-error{color:#ff6b6b}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.flex{display:flex}.flex-column{flex-direction:column}.justify-center{justify-content:center}.align-center{align-items:center}.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}input[type=datetime-local]{font-family:inherit;font-size:1rem;padding:.75rem;border:1px solid #ddd;border-radius:8px;background-color:var(--light-beige);color:var(--primary-dark)}input[type=datetime-local]:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 2px #74a57f33}input[type=datetime-local]::-webkit-calendar-picker-indicator{opacity:.7;cursor:pointer}
