.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2)}.login-box{background:#fff;padding:2.5rem;border-radius:.5rem;box-shadow:0 10px 25px #0003;width:100%;max-width:400px}.login-box h1{text-align:center;color:#2563eb;margin-bottom:.5rem;font-size:1.75rem}.login-box h2{text-align:center;color:#374151;margin-bottom:2rem;font-size:1.25rem;font-weight:500}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#374151;font-weight:500}.form-group input{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-group input:disabled{background-color:#f3f4f6;cursor:not-allowed}.btn-primary{width:100%;padding:.75rem;background-color:#2563eb;color:#fff;border:none;border-radius:.375rem;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.btn-primary:hover:not(:disabled){background-color:#1d4ed8}.btn-primary:disabled{background-color:#9ca3af;cursor:not-allowed}.error-message{background-color:#fee2e2;color:#991b1b;padding:.75rem;border-radius:.375rem;margin-bottom:1.5rem;font-size:.875rem}.login-info{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e5e7eb;font-size:.875rem;color:#6b7280}.login-info p{margin:.25rem 0}.dashboard h1{margin-bottom:2rem;color:#111827}.filters{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.filter-group label{font-size:.875rem;font-weight:500;color:#374151;display:flex;align-items:center;gap:.25rem}.required-indicator{color:#ef4444;font-weight:600;font-size:1rem}.filter-group select.required-field,.filter-group input.required-field{border-color:#fbbf24;background-color:#fffbeb}.filter-group select.required-field:focus,.filter-group input.required-field:focus{border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b1a}.btn-refresh{padding:.5rem 1rem;background-color:#2563eb;color:#fff;border:none;border-radius:.375rem;cursor:pointer;font-size:.875rem;align-self:flex-end;transition:background-color .2s}.charts-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));gap:2rem}.chart-box-full{grid-column:1 / -1;background:linear-gradient(135deg,#fff,#faf5ff);border:1px solid rgba(139,92,246,.2);box-shadow:0 4px 6px #8b5cf61a}.chart-box-full h2{color:#7c3aed;border-bottom:2px solid rgba(139,92,246,.3);padding-bottom:.75rem;margin-bottom:1.5rem}.chart-box h2{margin-bottom:1.5rem;color:#111827;font-size:1.25rem}.warning-message{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2.5rem 1.5rem;background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #fbbf24;border-radius:.5rem;margin:1rem 0;text-align:center;min-height:150px}.warning-icon{font-size:2.5rem;margin:0;margin-bottom:1rem;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}.warning-text{margin:0;color:#92400e;font-size:.9375rem;line-height:1.6;max-width:500px}.warning-text strong{color:#78350f;font-weight:600}.ranking-section{margin-top:2rem}.ranking-table-container{overflow-x:auto;margin-bottom:1.5rem}.ranking-table{width:100%;border-collapse:collapse;background:#fff;border-radius:.5rem;overflow:hidden}.ranking-table thead{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff}.ranking-table th{padding:1rem;text-align:left;font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.ranking-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background-color .2s}.ranking-table tbody tr:hover{background-color:#f9fafb}.ranking-table tbody tr:last-child{border-bottom:none}.ranking-table td{padding:1rem;font-size:.875rem;color:#374151}.ranking-cell{text-align:center;width:100px}.ranking-badge{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background-color:#e5e7eb;color:#6b7280;font-weight:600;font-size:.875rem}.ranking-badge.rank-1{background:linear-gradient(135deg,gold,#ffed4e);color:#92400e;box-shadow:0 2px 4px #ffd7004d}.ranking-badge.rank-2{background:linear-gradient(135deg,silver,#e5e5e5);color:#374151;box-shadow:0 2px 4px #c0c0c04d}.ranking-badge.rank-3{background:linear-gradient(135deg,#cd7f32,#e09d5c);color:#78350f;box-shadow:0 2px 4px #cd7f324d}.nama-cell{font-weight:500;color:#111827}.nama-link{background:none;border:none;color:#2563eb;font-weight:500;font-size:.875rem;cursor:pointer;padding:0;text-align:left;transition:color .2s,text-decoration .2s;text-decoration:underline;text-decoration-color:transparent}.nama-link:hover{color:#1d4ed8;text-decoration-color:#1d4ed8}.rata-rata-cell{text-align:right;font-weight:600}.rata-rata-value{display:inline-block;padding:.25rem .75rem;background-color:#f3f4f6;border-radius:.375rem;color:#1f2937;min-width:60px;text-align:center}.pagination{display:flex;justify-content:space-between;align-items:center;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e5e7eb;gap:1rem;flex-wrap:wrap}.pagination-btn{padding:.5rem 1rem;background-color:#8b5cf6;color:#fff;border:none;border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:background-color .2s}.pagination-btn:hover:not(:disabled){background-color:#7c3aed}.pagination-btn:disabled{background-color:#d1d5db;color:#9ca3af;cursor:not-allowed}.pagination-info{font-size:.875rem;color:#6b7280;flex:1;text-align:center}@media(max-width:768px){.charts-container{grid-template-columns:1fr}.ranking-table{font-size:.75rem}.ranking-table th,.ranking-table td{padding:.75rem .5rem}.ranking-badge{width:32px;height:32px;font-size:.75rem}.pagination{flex-direction:column;gap:.75rem}.pagination-info{order:-1}}.master-data h1{margin-bottom:2rem;color:#111827}.tabs{display:flex;gap:.5rem;margin-bottom:2rem;border-bottom:2px solid #e5e7eb}.tabs button{padding:.75rem 1.5rem;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;font-size:1rem;color:#6b7280;transition:all .2s;margin-bottom:-2px}.tabs button:hover{color:#2563eb}.tabs button.active{color:#2563eb;border-bottom-color:#2563eb;font-weight:500}.data-section{background:#fff;padding:2rem;border-radius:.5rem;box-shadow:0 1px 3px #0000001a}.data-section h2{margin-bottom:1.5rem;color:#111827;font-size:1.25rem}.form{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.form input,.form select{padding:.75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem}.btn-primary{padding:.75rem 1.5rem;background-color:#2563eb;color:#fff;border:none;border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:background-color .2s}.btn-primary:hover{background-color:#1d4ed8}table{width:100%;border-collapse:collapse;margin-top:1rem}.loading{text-align:center;padding:2rem;color:#6b7280}.input-nilai h1{margin-bottom:2rem;color:#111827}.filter-section{background:#fff;padding:1.5rem;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem}.filter-section label{display:block;margin-bottom:.5rem;font-weight:500;color:#374151}.select-relasi{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:1rem}.nilai-section{background:#fff;padding:2rem;border-radius:.5rem;box-shadow:0 1px 3px #0000001a}.info-box{background-color:#eff6ff;padding:1rem;border-radius:.375rem;margin-bottom:1.5rem}.info-box h2{color:#1e40af;margin-bottom:.5rem;font-size:1.25rem}.info-box p{color:#3b82f6;font-size:.875rem}table{width:100%;border-collapse:collapse}table thead{background-color:#f3f4f6}table th,table td{padding:.75rem;text-align:left;border-bottom:1px solid #e5e7eb}table th{font-weight:500;color:#374151}.input-nilai-angka{width:100px;padding:.5rem;border:1px solid #d1d5db;border-radius:.375rem;text-align:center}.nilai-huruf{font-weight:700;font-size:1.1rem}.btn-save{padding:.5rem 1rem;background-color:#2563eb;color:#fff;border:none;border-radius:.375rem;cursor:pointer;font-size:.875rem;transition:background-color .2s}.btn-save:hover:not(:disabled){background-color:#1d4ed8}.btn-save:disabled{background-color:#9ca3af;cursor:not-allowed}.raport h1{margin-bottom:2rem;color:#111827}.filter-group input,.filter-group select{padding:.5rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;min-width:150px}.autocomplete-wrapper,.autocomplete-container{position:relative}.autocomplete-input{width:100%;padding:.5rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;min-width:200px;transition:border-color .2s,box-shadow .2s}.autocomplete-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.autocomplete-suggestions{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #d1d5db;border-top:none;border-radius:0 0 .375rem .375rem;max-height:200px;overflow-y:auto;z-index:1000;box-shadow:0 4px 6px -1px #0000001a;margin-top:2px}.autocomplete-suggestion{padding:.75rem;cursor:pointer;transition:background-color .15s;border-bottom:1px solid #f3f4f6}.autocomplete-suggestion:last-child{border-bottom:none}.autocomplete-suggestion:hover{background-color:#f3f4f6}.autocomplete-suggestion:active{background-color:#e5e7eb}.btn-load,.btn-export{padding:.5rem 1rem;border:none;border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:background-color .2s;height:fit-content}.btn-load{background-color:#2563eb;color:#fff}.btn-load:hover{background-color:#1d4ed8}.btn-export{background-color:#16a34a;color:#fff}.btn-export:hover{background-color:#15803d}.raport-table-container{background:#fff;padding:1.5rem;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;overflow-x:auto}.raport-table{width:100%;border-collapse:collapse;font-size:.875rem}.raport-table thead{background-color:#f3f4f6;position:sticky;top:0}.raport-table th,.raport-table td{padding:.75rem;text-align:center;border:1px solid #e5e7eb}.raport-table th{font-weight:500;color:#374151;white-space:nowrap}.raport-table tbody tr:nth-child(2n){background-color:#f9fafb}.raport-table tbody tr:hover{background-color:#f3f4f6}.nilai-huruf{font-weight:700;font-size:1rem}.nilai-A{color:#16a34a}.nilai-B{color:#2563eb}.nilai-C{color:#eab308}.nilai-D{color:#ea580c}.nilai-E{color:#dc2626}.detail-siswa{padding:2rem;max-width:1400px;margin:0 auto}.detail-siswa-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}.detail-siswa-header h1{margin:0;color:#111827;font-size:1.875rem;font-weight:700}.btn-back{padding:.5rem 1rem;background-color:#6b7280;color:#fff;border:none;border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:background-color .2s;display:inline-flex;align-items:center;gap:.5rem}.btn-back:hover{background-color:#4b5563}.siswa-info-card{background:#fff;padding:1.5rem;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem}.siswa-info-card h2{margin:0 0 1.5rem;color:#111827;font-size:1.25rem;font-weight:600;border-bottom:2px solid #e5e7eb;padding-bottom:.75rem}.siswa-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.info-item{display:flex;flex-direction:column;gap:.5rem}.info-item label{font-size:.875rem;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.info-item span{font-size:1rem;color:#111827;font-weight:500}.filters{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap;align-items:flex-end}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-group label{font-size:.875rem;font-weight:500;color:#374151}.filter-group select,.filter-group input{padding:.5rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;transition:border-color .2s,box-shadow .2s}.filter-group select:focus,.filter-group input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.btn-refresh{padding:.5rem 1rem;background-color:#2563eb;color:#fff;border:none;border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:background-color .2s;height:fit-content}.btn-refresh:hover{background-color:#1d4ed8}.charts-container{display:grid;grid-template-columns:1fr;gap:2rem}.chart-box{background:#fff;padding:1.5rem;border-radius:.5rem;box-shadow:0 1px 3px #0000001a}.chart-box-full{background:linear-gradient(135deg,#fff,#faf5ff);border:1px solid rgba(139,92,246,.2);box-shadow:0 4px 6px #8b5cf61a}.chart-box h2{margin:0 0 1.5rem;color:#7c3aed;font-size:1.25rem;font-weight:600;border-bottom:2px solid rgba(139,92,246,.3);padding-bottom:.75rem}.loading,.no-data{text-align:center;padding:2rem;color:#6b7280}.error-message{text-align:center;padding:2rem;background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;color:#991b1b}.error-message p{margin:0 0 1rem;font-size:1rem;font-weight:500}@media(max-width:768px){.detail-siswa{padding:1rem}.detail-siswa-header{flex-direction:column;align-items:flex-start}.siswa-info-grid{grid-template-columns:1fr}.filters{flex-direction:column}.filter-group,.btn-refresh{width:100%}}.layout{min-height:100vh;display:flex;flex-direction:column}.header{background-color:#2563eb;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;font-weight:600}.header-right{display:flex;align-items:center;gap:1rem}.role-badge{background-color:#fff3;padding:.25rem .75rem;border-radius:.375rem;font-size:.875rem}.btn-logout{background-color:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:.5rem 1rem;border-radius:.375rem;cursor:pointer;font-size:.875rem}.btn-logout:hover{background-color:#ffffff4d}.container{display:flex;flex:1}.sidebar{width:250px;background-color:#fff;border-right:1px solid #e5e7eb;padding:1.5rem 0}.sidebar nav{display:flex;flex-direction:column}.nav-link{padding:.75rem 1.5rem;color:#374151;text-decoration:none;transition:all .3s ease;position:relative;display:block;border-left:3px solid transparent}.nav-link:hover{background-color:#f3f4f6;padding-left:1.75rem}.nav-link.active{background-color:#dbeafe;color:#2563eb;font-weight:600;border-left-color:#2563eb;box-shadow:inset 0 0 10px #2563eb1a;transform:translate(2px)}.nav-link.active:after{content:"";position:absolute;right:1rem;top:50%;transform:translateY(-50%);width:6px;height:6px;background-color:#2563eb;border-radius:50%;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-50%) scale(0)}to{opacity:1;transform:translateY(-50%) scale(1)}}@keyframes slideIn{0%{transform:scaleY(0);transform-origin:top}to{transform:scaleY(1);transform-origin:top}}.main-content{flex:1;padding:2rem;background-color:#f5f5f5}*{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}
