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:linear-gradient(135deg,#5ea8dd,#4a90c7);min-height:100vh}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:20px}.login-card{background:#fff;border-radius:16px;box-shadow:0 20px 40px #5ea8dd26;padding:48px;width:100%;max-width:400px;animation:slideUp .6s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:32px}.login-logo{width:80px;height:80px;margin-bottom:16px;display:block;margin-left:auto;margin-right:auto}.login-header h1{color:#2d3748;font-size:28px;font-weight:700;margin-bottom:8px}.login-header p{color:#718096;font-size:16px;font-weight:500}.login-form{display:flex;flex-direction:column;gap:24px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{color:#4a5568;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.form-group input{padding:16px;border:2px solid #e2e8f0;border-radius:8px;font-size:16px;transition:all .2s ease;background:#f7fafc}.form-group input:focus{outline:none;border-color:#5ea8dd;background:#fff;box-shadow:0 0 0 3px #5ea8dd1a}.form-group input::placeholder{color:#a0aec0}.error-message{background:#fed7d7;color:#c53030;padding:12px 16px;border-radius:8px;font-size:14px;font-weight:500;border:1px solid #feb2b2;text-align:center}.login-button{background:linear-gradient(135deg,#5ea8dd,#4a90c7);color:#fff;border:none;padding:16px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:8px}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #5ea8dd4d}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.login-footer{margin-top:24px;text-align:center}.login-footer p{color:#4a5568;font-size:14px}.link-button{background:none;border:none;color:#5ea8dd;font-size:14px;font-weight:600;cursor:pointer;text-decoration:underline;padding:0;margin:0}.link-button:hover{color:#4a90c7}@media (max-width: 480px){.login-card{padding:32px 24px;margin:16px}.login-logo{width:60px;height:60px}.login-header h1{font-size:24px}.form-group input,.login-button{padding:14px}}@media (max-width: 768px){.page-header{flex-direction:column;align-items:flex-start;gap:16px}.page-header h2{font-size:24px}.institution-form{padding:24px 20px;margin:0 16px}.form-row{grid-template-columns:1fr;gap:0}.form-actions{flex-direction:column}.cancel-button,.submit-button{width:100%}}.dashboard-loading{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#5ea8dd,#4a90c7);color:#fff}.loading-spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.3);border-top:4px solid white;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.dashboard-container{min-height:100vh;background:#f7fafc}.dashboard-header{background:#fff;border-bottom:1px solid #e2e8f0;padding:16px 24px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 1px 3px #5ea8dd1a}.header-content{display:flex;align-items:center;gap:16px}.header-logo{width:40px;height:40px}.header-text h1{color:#2d3748;font-size:24px;font-weight:700;margin:0}.header-text p{color:#718096;font-size:14px;margin:4px 0 0}.user-info{display:flex;align-items:center;gap:16px}.user-details{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.user-details span{color:#4a5568;font-size:14px;font-weight:500}.user-role{color:#5ea8dd!important;font-weight:600!important;font-size:12px!important;text-transform:uppercase;letter-spacing:.5px}.logout-button{background:#e53e3e;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.logout-button:hover{background:#c53030;transform:translateY(-1px)}.dashboard-main{padding:32px 24px;max-width:1200px;margin:0 auto}.dashboard-content{display:flex;flex-direction:column;gap:24px}.action-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;margin-top:24px}.action-card{background:#fff;border-radius:12px;padding:32px;box-shadow:0 4px 6px #5ea8dd0d;border:1px solid #e2e8f0;text-align:center;cursor:pointer}.action-icon{font-size:48px;margin-bottom:16px;display:block}.action-card h3{color:#2d3748;font-size:20px;font-weight:600;margin:0 0 12px}.action-card p{color:#4a5568;font-size:14px;line-height:1.5;margin:0}.welcome-card{background:#fff;border-radius:12px;padding:32px;box-shadow:0 4px 6px #5ea8dd0d;border:1px solid #e2e8f0}.welcome-card h2{color:#2d3748;font-size:28px;font-weight:700;margin:0 0 16px}.welcome-card>p{color:#4a5568;font-size:16px;line-height:1.6;margin:0 0 32px}.placeholder-message{background:#f7fafc;border:2px dashed #cbd5e0;border-radius:8px;padding:24px;text-align:center}.placeholder-message h3{color:#2d3748;font-size:20px;font-weight:600;margin:0 0 16px}.placeholder-message>p{color:#4a5568;font-size:16px;margin:0 0 20px}.placeholder-message ul{text-align:left;max-width:400px;margin:0 auto;color:#4a5568;font-size:14px;line-height:1.6}.placeholder-message li{margin-bottom:8px;padding-left:8px}.placeholder-message li::marker{color:#5ea8dd}@media (max-width: 768px){.dashboard-header{flex-direction:column;gap:16px;text-align:center}.header-content,.user-info{flex-direction:column;gap:12px}.user-details{align-items:center}.dashboard-main{padding:24px 16px}.action-cards{grid-template-columns:1fr;gap:16px}.action-card{padding:24px}.action-icon{font-size:40px}.action-card h3{font-size:18px}.welcome-card{padding:24px}.welcome-card h2{font-size:24px}.placeholder-message{padding:20px}.placeholder-message h3{font-size:18px}}.page-header{display:flex;align-items:center;gap:24px;margin-bottom:32px}.back-button{background:#5ea8dd;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s ease}.back-button:hover{background:#4a90c7}.page-header h2{color:#2d3748;font-size:28px;font-weight:700;margin:0}.search-container{margin-bottom:32px}.search-box{position:relative;max-width:600px;margin:0 auto}.search-input{width:100%;padding:16px 20px;border:2px solid #e2e8f0;border-radius:12px;font-size:16px;transition:border-color .2s ease;background:#fff;box-shadow:0 2px 4px #5ea8dd1a}.search-input:focus{outline:none;border-color:#5ea8dd;box-shadow:0 0 0 3px #5ea8dd1a}.search-input::placeholder{color:#a0aec0}.search-results{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:1000;max-height:300px;overflow-y:auto;margin-top:4px}.search-result-item{padding:12px 16px;cursor:pointer;border-bottom:1px solid #f1f5f9;transition:background-color .2s ease}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background-color:#f8fafc}.result-name{font-weight:600;color:#2d3748;font-size:14px;margin-bottom:4px}.result-details{color:#718096;font-size:12px}.selected-institution{background:#f0f9ff;border:1px solid #bae6fd;border-radius:8px;padding:16px 20px;margin-bottom:24px}.selected-institution h3{color:#0369a1;font-size:18px;font-weight:600;margin:0 0 8px}.selected-institution p{color:#0c4a6e;font-size:14px;margin:0}.form-container{max-width:800px;margin:0 auto}.institution-form{background:#fff;border-radius:12px;padding:32px;box-shadow:0 4px 6px #5ea8dd0d;border:1px solid #e2e8f0}.form-section{margin-bottom:32px}.form-section:last-of-type{margin-bottom:24px}.form-section h3{color:#2d3748;font-size:18px;font-weight:600;margin:0 0 20px;padding-bottom:8px;border-bottom:2px solid #e2e8f0}.form-group{margin-bottom:20px}.form-group label{display:block;color:#4a5568;font-size:14px;font-weight:600;margin-bottom:6px}.form-group input,.form-group textarea,.form-group select{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;transition:border-color .2s ease;background:#f7fafc}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#5ea8dd;background:#fff;box-shadow:0 0 0 3px #5ea8dd1a}.form-group input::placeholder,.form-group textarea::placeholder{color:#a0aec0}.form-group select{cursor:pointer}.form-group select option{padding:8px}.form-group small{display:block;color:#718096;font-size:12px;margin-top:4px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-actions{display:flex;gap:16px;justify-content:flex-end;padding-top:24px;border-top:1px solid #e2e8f0}.cancel-button{background:#e2e8f0;color:#4a5568;border:none;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s ease}.cancel-button:hover{background:#cbd5e0}.submit-button{background:#5ea8dd;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s ease}.submit-button:hover:not(:disabled){background:#4a90c7}.submit-button:disabled{opacity:.6;cursor:not-allowed}.image-upload-container{width:100%}.upload-area{position:relative;width:100%;height:120px;border:2px dashed #cbd5e0;border-radius:8px;display:flex;align-items:center;justify-content:center;background:#f7fafc;transition:all .2s ease;cursor:pointer}.upload-area:hover{border-color:#5ea8dd;background:#f0f9ff}.upload-area:has(.file-input:disabled){opacity:.6;cursor:not-allowed}.file-input{position:absolute;width:100%;height:100%;opacity:0;cursor:pointer}.file-input:disabled{cursor:not-allowed}.upload-label{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;cursor:pointer;pointer-events:none}.upload-icon{font-size:24px;margin-bottom:8px}.upload-label span{color:#4a5568;font-size:14px;font-weight:500;margin-bottom:4px}.upload-label small{color:#718096;font-size:12px}.upload-loading{display:flex;flex-direction:column;align-items:center;gap:8px}.upload-loading span{color:#4a5568;font-size:14px;font-weight:500}.spinner{width:20px;height:20px;border:2px solid #e2e8f0;border-top:2px solid #5ea8dd;border-radius:50%;animation:spin 1s linear infinite}.image-preview{position:relative;width:100%;height:120px;border-radius:8px;overflow:hidden;background:#f7fafc}.image-preview img{width:100%;height:100%;object-fit:cover}.remove-image-btn{position:absolute;top:8px;right:8px;width:24px;height:24px;border:none;border-radius:50%;background:#ef4444e6;color:#fff;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease}.remove-image-btn:hover{background:#ef4444}@media (max-width: 768px){.page-header{flex-direction:column;align-items:flex-start;gap:16px}.page-header h2{font-size:24px}.search-box{margin:0 16px}.search-input{padding:14px 16px;font-size:14px}.selected-institution{margin:0 16px 24px}.institution-form{padding:24px 20px;margin:0 16px}.form-row{grid-template-columns:1fr;gap:0}.form-actions{flex-direction:column}.cancel-button,.submit-button{width:100%}}.app-loading{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#5ea8dd,#4a90c7);color:#fff}.app-loading .loading-spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.3);border-top:4px solid white;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;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}#root{height:100%}
