.login-container{align-items:center;background:linear-gradient(135deg,#0078d4,#50e6ff);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-box{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;max-width:500px;padding:40px;width:100%}.login-header{margin-bottom:40px;text-align:center}.login-header h1{color:#0078d4;font-size:32px;margin:0 0 10px}.login-header p{color:#707070;font-size:16px;margin:0}.login-content{display:flex;flex-direction:column;gap:20px}.login-description{color:#404040;line-height:1.6;margin:0}.btn-login{background-color:#0078d4;border:none;border-radius:6px;box-shadow:0 4px 8px #0078d44d;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:14px 24px;transition:all .3s ease}.btn-login:hover{background-color:#005a9e;box-shadow:0 6px 12px #0078d466;transform:translateY(-2px)}.btn-login:active{transform:translateY(0)}.login-info{background-color:#e7f1f8;border-left:4px solid #0078d4;border-radius:6px;padding:20px}.login-info h3{color:#0078d4;font-size:14px;margin:0 0 12px}.login-info ul{color:#404040;font-size:13px;line-height:1.8;list-style-type:disc;margin:0;padding-left:20px}.login-info li{margin-bottom:6px}@media (max-width:480px){.login-box{padding:30px 20px}.login-header h1{font-size:24px}.btn-login{font-size:14px;padding:12px 20px}}.dashboard{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.dashboard h1{color:#0078d4;margin-bottom:30px}.dashboard-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin-bottom:20px}.dashboard-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:25px}.dashboard-card h2{border-bottom:2px solid #e7f1f8;color:#0078d4;font-size:18px;margin:0 0 20px;padding-bottom:12px}.user-info{display:flex;flex-direction:column;gap:15px}.info-row{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:10px 0}.info-row:last-child{border-bottom:none}.info-row .label{color:#404040;font-weight:600}.info-row .value{color:#707070}.badge{border-radius:20px;display:inline-block;font-size:13px;font-weight:600;padding:6px 12px}.badge[data-role=student]{background-color:#e7f5e7;color:#107c10}.badge[data-role=teacher]{background-color:#fff4ce;color:#ff8c00}.badge[data-role=admin]{background-color:#fde7e7;color:#d83b01}.quick-actions{display:flex;flex-direction:column;gap:12px}.action-link{align-items:center;background-color:#f5f5f5;border-left:4px solid #0000;border-radius:6px;display:flex;gap:15px;padding:15px;text-decoration:none;transition:all .2s ease}.action-link:hover{background-color:#e7f1f8;border-left-color:#0078d4;transform:translateX(5px)}.action-icon{font-size:32px}.action-text{color:#0078d4;display:flex;flex-direction:column}.action-title{color:#0078d4;font-weight:600}.action-desc{color:#707070;font-size:13px}.info-card{background:linear-gradient(135deg,#e7f1f8,#f5f5f5);border-left:4px solid #0078d4}.info-card ul{color:#404040;line-height:1.8;list-style-type:disc;margin:0;padding-left:20px}.info-card li{margin-bottom:12px}@media (max-width:768px){.dashboard-grid{grid-template-columns:1fr}.dashboard h1{font-size:24px}}.projects{animation:fadeIn .3s ease-in}.projects h1{color:#0078d4;margin-bottom:25px}.projects-filter{grid-gap:15px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:30px;padding:20px}.filter-group{display:flex;flex-direction:column;gap:8px}.filter-group label{color:#404040;font-size:14px;font-weight:600}.filter-group input,.filter-group select{border:1px solid #d0d0d0;border-radius:4px;font-size:14px;padding:10px}.filter-group input:focus,.filter-group select:focus{border-color:#0078d4;box-shadow:0 0 0 3px #e7f1f8;outline:none}.projects-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));margin-top:20px}.project-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;gap:15px;padding:20px;transition:all .3s ease}.project-card:hover{box-shadow:0 8px 16px #00000026;transform:translateY(-4px)}.project-header{gap:10px}.project-header h3{color:#0078d4;flex:1 1;font-size:18px;margin:0}.status-badge{font-size:12px;padding:4px 12px}.status-open{background-color:#e7f5e7;color:#107c10}.status-full{background-color:#fde7e7;color:#d83b01}.status-cancelled{background-color:#f5f5f5;color:#707070}.project-description{color:#404040;flex:1 1;line-height:1.5;margin:0}.project-meta{border-bottom:1px solid #e0e0e0;border-top:1px solid #e0e0e0;display:flex;flex-direction:column;gap:8px;padding:12px 0}.meta-item{align-items:center;display:flex;justify-content:space-between}.meta-label{color:#707070;font-size:13px;font-weight:600}.meta-value{color:#404040;font-size:13px}.spots-available{background-color:#e7f5e7;color:#107c10;font-size:13px;font-weight:500;padding:8px 12px}.btn-view,.spots-available{border-radius:4px;text-align:center}.btn-view{background-color:#0078d4;color:#fff;font-weight:600;padding:10px;text-decoration:none;transition:all .2s ease}.btn-view:hover{background-color:#005a9e}.no-projects{background:#fff;border-radius:8px;color:#707070;padding:40px;text-align:center}@media (max-width:768px){.projects-grid{grid-template-columns:1fr}.projects h1{font-size:24px}}.project-detail{animation:fadeIn .3s ease-in}.btn-back{background:none;border:none;color:#0078d4;cursor:pointer;font-size:16px;font-weight:600;margin-bottom:20px;padding:0;transition:color .2s ease}.btn-back:hover{color:#005a9e}.project-detail-content{grid-gap:30px;display:grid;gap:30px;grid-template-columns:1fr 350px}.project-main{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:30px}.project-header{align-items:flex-start;border-bottom:2px solid #e0e0e0;display:flex;gap:15px;justify-content:space-between;margin-bottom:30px;padding-bottom:20px}.project-header h1{color:#0078d4;flex:1 1;margin:0}.project-info{display:flex;flex-direction:column;gap:30px}.info-section h3{color:#0078d4;font-size:16px;margin:0 0 12px}.info-section p{color:#404040;line-height:1.6;margin:0}.info-grid{grid-gap:20px;background-color:#f5f5f5;border-radius:6px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));padding:20px}.info-item{display:flex;flex-direction:column;gap:5px}.info-item .label{color:#707070;font-size:13px;font-weight:600}.info-item .value{color:#0078d4;font-size:18px;font-weight:600}.tags{display:flex;flex-wrap:wrap;gap:8px}.tag{background-color:#e7f1f8;border-radius:12px;color:#0078d4;font-size:12px;font-weight:500;padding:4px 10px}.project-sidebar{display:flex;flex-direction:column}.apply-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:25px;position:-webkit-sticky;position:sticky;top:20px}.apply-card h2{border-bottom:2px solid #e7f1f8;color:#0078d4;font-size:18px;margin:0 0 20px;padding-bottom:12px}.apply-card form{display:flex;flex-direction:column;gap:15px}.form-group label{font-size:14px;margin-bottom:6px}.form-group select,.form-group textarea{border:1px solid #d0d0d0;border-radius:4px;font-family:inherit;font-size:14px;padding:10px}.form-group textarea{color:#404040;resize:vertical}.form-group select:focus,.form-group textarea:focus{border-color:#0078d4;box-shadow:0 0 0 3px #e7f1f8;outline:none}.existing-application{background-color:#e7f5e7;border-left:4px solid #107c10;border-radius:4px;padding:15px}.existing-application .info-text{color:#107c10;font-weight:600;margin:0 0 12px}.application-details{background:#fff;border-radius:4px;margin-bottom:12px;padding:12px}.application-details p{color:#404040;font-size:13px;line-height:1.6;margin:0}.not-available{background-color:#fde7e7;border-left:4px solid #d83b01;border-radius:4px;padding:15px;text-align:center}.not-available p{color:#d83b01;font-weight:600;margin:0}.btn-primary,.btn-secondary{border:none;border-radius:4px;cursor:pointer;font-weight:600;padding:12px;transition:all .2s ease;width:100%}.btn-primary:hover:not(:disabled){background-color:#005a9e}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.btn-secondary{background-color:#e0e0e0;color:#404040}.btn-secondary:hover{background-color:#d0d0d0}@media (max-width:1024px){.project-detail-content{grid-template-columns:1fr}.apply-card{position:static}}@media (max-width:768px){.project-main{padding:20px}.project-header{flex-direction:column}.info-grid{grid-template-columns:1fr}}.my-applications{animation:fadeIn .3s ease-in}.my-applications h1{color:#0078d4;margin-bottom:25px}.applications-filter{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;gap:15px;margin-bottom:25px;padding:15px 20px}.applications-filter label{color:#404040;font-weight:600;white-space:nowrap}.applications-filter select{border:1px solid #d0d0d0;border-radius:4px;font-size:14px;min-width:200px;padding:8px 12px}.applications-filter select:focus{border-color:#0078d4;box-shadow:0 0 0 3px #e7f1f8;outline:none}.applications-list{display:flex;flex-direction:column;gap:15px}.application-item{background:#fff;border-left:4px solid #0078d4;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:20px;transition:all .2s ease}.application-item:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.app-header{align-items:flex-start;border-bottom:1px solid #e0e0e0;display:flex;gap:15px;justify-content:space-between;margin-bottom:20px;padding-bottom:15px}.app-header h3{color:#0078d4;flex:1 1;font-size:18px;margin:0}.status-badge{border-radius:12px;font-size:13px;font-weight:600;padding:6px 12px;white-space:nowrap}.status-pending{background-color:#fff4ce;color:#ff8c00}.status-accepted{background-color:#e7f5e7;color:#107c10}.status-rejected{background-color:#fde7e7;color:#d83b01}.status-withdrawn{background-color:#f5f5f5;color:#707070}.status-default{background-color:#e7f1f8;color:#0078d4}.app-details{display:flex;flex-direction:column;gap:12px;margin-bottom:15px}.detail-row{align-items:center;display:flex;justify-content:space-between}.detail-row .label{color:#707070;font-size:14px;font-weight:600}.detail-row .value{color:#404040;font-size:14px}.detail-section{background-color:#f5f5f5;border-radius:4px;display:flex;flex-direction:column;gap:8px;padding:12px}.detail-section .label{color:#707070;font-size:13px;font-weight:600}.motivation{color:#404040;font-size:13px;line-height:1.6;margin:0;white-space:pre-wrap;word-break:break-word}.btn-withdraw{align-self:flex-start;background-color:#ff8c00;border:none;border-radius:4px;color:#fff;cursor:pointer;font-weight:600;padding:10px 15px;transition:all .2s ease}.btn-withdraw:hover{background-color:#e67e00}.no-applications{background:#fff;border-radius:8px;color:#707070;padding:40px;text-align:center}.no-applications p{margin:0 0 20px}.no-applications .btn-primary{background-color:#0078d4;border-radius:4px;color:#fff;display:inline-block;font-weight:600;padding:12px 24px;text-decoration:none;transition:all .2s ease}.no-applications .btn-primary:hover{background-color:#005a9e}@media (max-width:768px){.applications-filter{align-items:flex-start;flex-direction:column}.applications-filter select{min-width:auto;width:100%}.app-header,.detail-row{flex-direction:column}.detail-row{align-items:flex-start;gap:4px}}.navbar{background-color:#0078d4;box-shadow:0 2px 4px #0000001a;color:#fff;padding:0}.navbar-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:15px 20px}.navbar-brand h2{color:#fff;font-size:20px;margin:0}.navbar-menu{display:flex;flex:1 1;gap:30px;list-style:none;margin:0 30px}.navbar-menu a{color:#fff;font-weight:500;text-decoration:none;transition:color .2s ease}.navbar-menu a:hover{color:#e7f1f8}.navbar-user{align-items:center;display:flex;gap:15px}.btn-logout,.user-name{font-weight:500}.btn-logout{background-color:#fff3;border:1px solid #fff;border-radius:4px;color:#fff;cursor:pointer;padding:8px 16px;transition:all .2s ease}.btn-logout:hover{background-color:#ffffff4d}@media (max-width:768px){.navbar-menu{margin:0 15px}.navbar-container{flex-wrap:wrap;gap:15px}.navbar-menu{gap:15px;order:3;width:100%}}:root{--primary-color:#0078d4;--primary-dark:#005a9e;--primary-light:#e7f1f8;--secondary-color:#50e6ff;--success-color:#107c10;--warning-color:#ff8c00;--danger-color:#d83b01;--gray-100:#f5f5f5;--gray-200:#e0e0e0;--gray-300:#d0d0d0;--gray-400:#a0a0a0;--gray-500:#707070;--gray-600:#404040;--gray-800:#202020;--shadow-sm:0 2px 4px #0000001a;--shadow-md:0 4px 8px #00000026;--shadow-lg:0 8px 16px #0003}*{box-sizing:border-box;margin:0;padding:0}body{background-color:#f5f5f5;background-color:var(--gray-100);color:#202020;color:var(--gray-800);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6}.App{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1 1;margin:0 auto;max-width:1200px;padding:20px;width:100%}button{border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.btn-primary{background-color:#0078d4;background-color:var(--primary-color);color:#fff}.btn-primary:hover{background-color:#005a9e;background-color:var(--primary-dark);box-shadow:0 4px 8px #00000026;box-shadow:var(--shadow-md)}.btn-primary:active{transform:scale(.98)}.btn-secondary{background-color:#d0d0d0;background-color:var(--gray-300);color:#202020;color:var(--gray-800)}.btn-secondary:hover{background-color:#a0a0a0;background-color:var(--gray-400)}.btn-success{background-color:#107c10;background-color:var(--success-color);color:#fff}.btn-success:hover{background-color:#0d6a0d}.btn-danger{background-color:#d83b01;background-color:var(--danger-color);color:#fff}.btn-danger:hover{background-color:#b92b00}.card{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;box-shadow:var(--shadow-sm);margin-bottom:20px;padding:20px}.card:hover{box-shadow:0 4px 8px #00000026;box-shadow:var(--shadow-md);transition:box-shadow .2s ease}input[type=email],input[type=password],input[type=text],select,textarea{border:1px solid #d0d0d0;border:1px solid var(--gray-300);border-radius:4px;font-family:inherit;font-size:14px;margin-bottom:10px;padding:10px;width:100%}input:focus,select:focus,textarea:focus{border-color:#0078d4;border-color:var(--primary-color);box-shadow:0 0 0 3px #e7f1f8;box-shadow:0 0 0 3px var(--primary-light);outline:none}.form-group{margin-bottom:20px}.form-group label{color:#404040;color:var(--gray-600);display:block;font-weight:600;margin-bottom:8px}.grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.grid-2{grid-template-columns:repeat(auto-fit,minmax(400px,1fr))}h1,h2,h3,h4,h5,h6{color:#202020;color:var(--gray-800);margin-bottom:15px}h1{font-size:32px}h2{font-size:24px}h3{font-size:20px}.text-center{text-align:center}.text-muted{color:#707070;color:var(--gray-500)}.mt-20{margin-top:20px}.mb-20{margin-bottom:20px}.p-20{padding:20px}.text-success{color:#107c10;color:var(--success-color)}.text-danger{color:#d83b01;color:var(--danger-color)}.text-warning{color:#ff8c00;color:var(--warning-color)}.loading{align-items:center;display:flex;justify-content:center;padding:40px}.loading-spinner{animation:spin .8s linear infinite;border:4px solid #d0d0d0;border-top-color:#0078d4;border:4px solid var(--gray-300);border-radius:50%;border-top-color:var(--primary-color);height:40px;width:40px}@keyframes spin{to{transform:rotate(1turn)}}.error-message{background-color:#fde7e7;border-left:4px solid #d83b01;border-left:4px solid var(--danger-color);color:#d83b01;color:var(--danger-color)}.error-message,.success-message{border-radius:4px;margin-bottom:15px;padding:12px}.success-message{background-color:#e7f5e7;border-left:4px solid #107c10;border-left:4px solid var(--success-color);color:#107c10;color:var(--success-color)}@media (max-width:768px){.grid,.grid-2{grid-template-columns:1fr}h1{font-size:24px}.main-content{padding:15px}}
/*# sourceMappingURL=main.d973d63d.css.map*/