:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;font-weight:400;color-scheme:light;color:#374151;background-color:#fff;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;font-family:inherit;line-height:1.6;color:#374151;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);min-height:100vh}#root{min-height:100vh}a{color:#2563eb;text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3,h4,h5,h6{color:#1f2937;line-height:1.3;margin:0}button{border-radius:8px;border:none;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;cursor:pointer;transition:all .3s ease}button:focus,button:focus-visible{outline:2px solid #2563eb;outline-offset:2px}input,textarea,select{font-family:inherit;font-size:inherit}input:focus,textarea:focus,select:focus{outline:none}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.navbar{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 10px #0000001a;position:sticky;top:0;z-index:100}.nav-container{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center;height:70px}.nav-logo{font-size:1.5rem;font-weight:700;color:#fff;text-decoration:none;transition:color .3s ease}.nav-logo:hover{color:#e0e7ff}.nav-menu{display:flex;gap:2rem}.nav-link{color:#fff;text-decoration:none;font-weight:500;font-size:1rem;padding:.5rem 1rem;border-radius:8px;transition:all .3s ease;position:relative}.nav-link:hover{background:#ffffff1a;transform:translateY(-1px)}.nav-link.active{background:#fff3}@media (max-width: 768px){.nav-container{padding:0 1rem;height:60px}.nav-logo{font-size:1.25rem}.nav-menu{gap:1rem}.nav-link{font-size:.9rem;padding:.4rem .8rem}}@media (max-width: 480px){.nav-container{flex-direction:column;height:auto;padding:1rem}.nav-menu{margin-top:.5rem}}.image-upload-container{margin-bottom:1.5rem}.image-upload-label{display:block;font-weight:600;margin-bottom:.5rem;color:#374151;font-size:.95rem}.upload-area{border:2px dashed #d1d5db;border-radius:12px;padding:2rem;text-align:center;background:#f9fafb;transition:all .3s ease;cursor:pointer;position:relative}.upload-area:hover:not(.disabled){border-color:#2563eb;background:#eff6ff}.upload-area.drag-active{border-color:#2563eb;background:#eff6ff;transform:scale(1.02)}.upload-area.disabled{opacity:.6;cursor:not-allowed;background:#f3f4f6}.file-input{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}.file-input:disabled{cursor:not-allowed}.upload-content{pointer-events:none}.upload-icon{font-size:3rem;margin-bottom:1rem;opacity:.6}.upload-text{font-size:1.1rem;font-weight:500;color:#374151;margin-bottom:.5rem}.upload-subtext{font-size:.9rem;color:#6b7280;margin:0}.image-preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem;margin-top:1rem}.image-preview-item{position:relative;border-radius:8px;overflow:hidden;background:#f3f4f6;aspect-ratio:1}.image-preview-item img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.image-preview-item:hover img{transform:scale(1.05)}.remove-image-btn{position:absolute;top:.5rem;right:.5rem;width:24px;height:24px;border-radius:50%;background:#ef4444;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;transition:all .3s ease;opacity:.8}.remove-image-btn:hover{opacity:1;background:#dc2626;transform:scale(1.1)}@media (max-width: 768px){.upload-area{padding:1.5rem}.upload-icon{font-size:2.5rem}.upload-text{font-size:1rem}.image-preview-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.75rem}}@media (max-width: 480px){.upload-area{padding:1rem}.upload-icon{font-size:2rem}.upload-text{font-size:.9rem}.upload-subtext{font-size:.8rem}.image-preview-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.5rem}}.portfolio-form-container{max-width:800px;margin:0 auto;padding:2rem;background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a}.portfolio-form-container h2{text-align:center;color:#2563eb;margin-bottom:2rem;font-size:1.75rem;font-weight:700}.portfolio-form{display:grid;gap:1.5rem}.form-group{display:flex;flex-direction:column}.form-group label{font-weight:600;margin-bottom:.5rem;color:#374151;font-size:.95rem}.form-group input,.form-group textarea,.form-group select{padding:.75rem;border:2px solid #d1d5db;border-radius:8px;font-size:1rem;transition:border-color .2s ease,box-shadow .2s ease}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-group textarea{resize:vertical;min-height:100px}.error{color:#dc2626;font-size:.875rem;margin-top:.25rem;font-weight:500}.submit-btn{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:1rem}.submit-btn:hover{background:linear-gradient(135deg,#1d4ed8,#1e40af);transform:translateY(-2px);box-shadow:0 8px 15px #2563eb4d}.submit-btn:active{transform:translateY(0)}.image-upload-section{margin-top:2rem;padding:2rem;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0}.image-upload-section h3{color:#1e40af;font-size:1.25rem;font-weight:600;margin-bottom:1.5rem;text-align:center;padding-bottom:.5rem;border-bottom:2px solid #e2e8f0}@media (max-width: 768px){.portfolio-form-container{margin:1rem;padding:1.5rem}.portfolio-form-container h2{font-size:1.5rem}.form-group input,.form-group textarea,.form-group select{padding:.625rem;font-size:.95rem}}.student-list-container{max-width:1200px;margin:0 auto;padding:2rem}.header{text-align:center;margin-bottom:2rem}.header h2{color:#1f2937;font-size:2rem;font-weight:700;margin-bottom:.5rem}.subtitle{color:#6b7280;font-size:1.1rem;margin:0}.empty-state{text-align:center;padding:4rem 2rem;background:#f9fafb;border-radius:12px;border:2px dashed #d1d5db}.empty-state p{color:#6b7280;font-size:1.2rem;margin-bottom:1.5rem}.add-student-link,.add-student-btn{display:inline-block;background:linear-gradient(135deg,#10b981,#059669);color:#fff;text-decoration:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;transition:all .3s ease}.add-student-link:hover,.add-student-btn:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-2px);box-shadow:0 8px 15px #10b9814d}.table-container{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 6px #0000001a;margin-bottom:2rem}.student-table{width:100%;border-collapse:collapse}.student-table thead{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.student-table th,.student-table td{padding:1rem;text-align:left;border-bottom:1px solid #e5e7eb}.student-table th{font-weight:600;font-size:.95rem;letter-spacing:.025em}.student-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s ease}.student-table th.sortable:hover{background:#ffffff1a}.student-row{transition:background-color .2s ease}.student-row:hover{background:#f8fafc}.gpa{padding:.25rem .5rem;border-radius:6px;font-weight:600;font-size:.9rem}.gpa.excellent{background:#dcfce7;color:#166534}.gpa.good{background:#dbeafe;color:#1e40af}.gpa.fair{background:#fef3c7;color:#92400e}.gpa.poor{background:#fee2e2;color:#991b1b}.detail-link{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;text-decoration:none;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;font-weight:500;transition:all .3s ease;display:inline-block}.detail-link:hover{background:linear-gradient(135deg,#7c3aed,#6d28d9);transform:translateY(-1px);box-shadow:0 4px 8px #8b5cf64d}.actions{text-align:center}@media (max-width: 768px){.student-list-container{padding:1rem}.header h2{font-size:1.5rem}.table-container{overflow-x:auto}.student-table{min-width:600px}.student-table th,.student-table td{padding:.75rem .5rem;font-size:.9rem}}@media (max-width: 480px){.student-table th,.student-table td{padding:.5rem .25rem;font-size:.8rem}.detail-link{padding:.375rem .75rem;font-size:.8rem}}.student-detail-container{max-width:900px;margin:0 auto;padding:2rem}.detail-header{margin-bottom:2rem}.back-link{display:inline-block;color:#6b7280;text-decoration:none;font-weight:500;margin-bottom:1rem;transition:color .2s ease}.back-link:hover{color:#374151}.detail-header h2{color:#1f2937;font-size:2rem;font-weight:700;margin:0}.not-found{text-align:center;padding:4rem 2rem;background:#f9fafb;border-radius:12px;border:2px dashed #d1d5db}.not-found h2{color:#374151;margin-bottom:1.5rem}.student-card{background:#fff;border-radius:16px;box-shadow:0 10px 25px #0000001a;overflow:hidden}.profile-section{display:flex;align-items:center;padding:2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.profile-image{width:120px;height:120px;border-radius:50%;overflow:hidden;margin-right:2rem;background:#fff3;display:flex;align-items:center;justify-content:center}.profile-image img{width:100%;height:100%;object-fit:cover}.placeholder-image{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#ffffff4d;font-size:2rem;font-weight:700;color:#fff}.basic-info h3{font-size:1.75rem;font-weight:700;margin:0 0 1rem}.gpa-badge .gpa{padding:.5rem 1rem;border-radius:25px;font-weight:600;font-size:1rem;display:inline-block}.gpa.excellent{background:#10b981;color:#fff}.gpa.good{background:#3b82f6;color:#fff}.gpa.fair{background:#f59e0b;color:#fff}.gpa.poor{background:#ef4444;color:#fff}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;padding:2rem;border-bottom:1px solid #e5e7eb}.info-section h4{color:#374151;font-size:1.2rem;font-weight:600;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #e5e7eb}.info-item{display:flex;flex-direction:column;margin-bottom:1rem}.info-item label{font-weight:600;color:#6b7280;font-size:.9rem;margin-bottom:.25rem}.info-item span{color:#374151;font-size:1rem}.description-section{padding:2rem;border-bottom:1px solid #e5e7eb}.description-item{margin-bottom:2rem}.description-item:last-child{margin-bottom:0}.description-item h4{color:#374151;font-size:1.2rem;font-weight:600;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #e5e7eb}.description-item p{color:#4b5563;line-height:1.6;font-size:1rem;margin:0}.gallery-section{padding:2rem}.gallery-item{margin-bottom:2rem}.gallery-item:last-child{margin-bottom:0}.gallery-item h4{color:#374151;font-size:1.2rem;font-weight:600;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #e5e7eb}.image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.image-grid img{width:100%;height:200px;object-fit:cover;border-radius:8px;box-shadow:0 4px 6px #0000001a;transition:transform .3s ease,box-shadow .3s ease}.image-grid img:hover{transform:scale(1.05);box-shadow:0 8px 15px #0003}@media (max-width: 768px){.student-detail-container{padding:1rem}.profile-section{flex-direction:column;text-align:center;padding:1.5rem}.profile-image{margin-right:0;margin-bottom:1rem}.info-grid{grid-template-columns:1fr;gap:1.5rem;padding:1.5rem}.description-section,.gallery-section{padding:1.5rem}.image-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.image-grid img{height:150px}}@media (max-width: 480px){.detail-header h2,.basic-info h3{font-size:1.5rem}.profile-image{width:100px;height:100px}.placeholder-image{font-size:1.5rem}.image-grid{grid-template-columns:1fr 1fr}.image-grid img{height:120px}}.App{min-height:100vh}.main-content{padding-top:2rem;padding-bottom:2rem;min-height:calc(100vh - 70px)}.text-center{text-align:center}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}@media (max-width: 768px){.main-content{padding-top:1rem;padding-bottom:1rem}}
