*{box-sizing:border-box;margin:0;padding:0}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:#0f172a;color:#e2e8f0;line-height:1.5}.App{min-height:100vh;display:flex;flex-direction:column}.App-header{background:linear-gradient(135deg,#1e293b 0%,#0f172a 100%);color:#e2e8f0;padding:2rem 1rem;text-align:center;box-shadow:0 4px 12px #00000080;border-bottom:1px solid #334155}.App-header h1{font-size:2.5rem;margin-bottom:.5rem}.App-header p{font-size:1.1rem;opacity:.9;max-width:600px;margin:0 auto}.App-main{flex:1;padding:1.5rem 1rem;background-color:#0f172a}.container{max-width:1200px;margin:0 auto;padding:0 1rem}section{background:transparent;border-radius:0;padding:0;margin-bottom:0;box-shadow:none;border:none}section h2{font-size:1.8rem;margin-bottom:1.5rem;color:#e2e8f0;border-bottom:2px solid #334155;padding-bottom:.5rem}.form-group{margin-bottom:1.2rem}.form-group label{display:block;font-weight:600;margin-bottom:.4rem;color:#cbd5e1;font-size:.95rem}.form-group input[type=text],.form-group textarea,.form-group input[type=number]{width:100%;padding:.7rem .875rem;border:1px solid #475569;border-radius:6px;font-size:.95rem;transition:border-color .2s,box-shadow .2s;background-color:#0f172a;color:#e2e8f0}.form-group input[type=file]{width:100%;padding:.7rem .875rem;border:1px solid #475569;border-radius:6px;font-size:.95rem;transition:border-color .2s,box-shadow .2s;background-color:#0f172a;color:#e2e8f0;cursor:pointer}.form-group input[type=file]::file-selector-button{padding:.5rem 1rem;background-color:#334155;color:#e2e8f0;border:none;border-radius:4px;cursor:pointer;font-weight:600;font-size:.85rem;margin-right:.75rem;transition:all .2s}.form-group input[type=file]::file-selector-button:hover{background-color:#475569}.form-group input[type=text]:focus,.form-group textarea:focus,.form-group input[type=number]:focus,.form-group input[type=file]:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group textarea{resize:vertical;min-height:90px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.form-group small{display:block;margin-top:.4rem;color:#94a3b8;font-size:.8rem}button{cursor:pointer;font-weight:600;font-size:.95rem;border:none;border-radius:6px;padding:.7rem 1.4rem;transition:all .2s}.submit-btn{background:linear-gradient(135deg,#10b981 0%,#059669 100%);color:#fff}.submit-btn:hover{background:linear-gradient(135deg,#0da271 0%,#047857 100%);transform:translateY(-2px);box-shadow:0 4px 8px #0596694d}.save-btn{background:linear-gradient(135deg,#3b82f6 0%,#1d4ed8 100%);color:#fff}.save-btn:hover{background:linear-gradient(135deg,#2563eb 0%,#1e40af 100%);transform:translateY(-2px);box-shadow:0 4px 8px #1d4ed84d}.cancel-btn,.back-to-list{background:#475569;color:#e2e8f0;margin-left:0}.cancel-btn:hover,.back-to-list:hover{background:#64748b}.edit-btn{background:#fbbf24;color:#78350f;padding:.4rem .9rem;font-size:.8rem}.edit-btn:hover{background:#f59e0b}.delete-btn{background:#ef4444;color:#fff;padding:.4rem .9rem;font-size:.8rem;margin-left:.3rem}.delete-btn:hover{background:#dc2626}.form-actions{display:flex;align-items:center;gap:.75rem;margin-top:1.5rem}.skill-create,.skill-edit{background:#1e293b;border-radius:8px;padding:1.5rem;border:1px solid #334155}.skill-create h2,.skill-edit h2{font-size:1.5rem;color:#e2e8f0;margin-bottom:1.5rem;border-bottom:1px solid #334155;padding-bottom:1rem}.skills-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:1rem}.skill-card{border:1px solid #334155;border-radius:8px;padding:1.25rem;background:#1e293b;transition:all .3s ease;display:flex;flex-direction:column;min-height:auto;max-height:380px;position:relative}.skill-card:hover{transform:translateY(-3px);box-shadow:0 8px 16px #0000004d;border-color:#475569;background:#293548}.skill-list{background-color:#0f172a}.skill-list-header{margin-bottom:1.5rem}.skill-list-title h2{font-size:1.5rem;color:#e2e8f0;margin-bottom:.25rem;border-bottom:1px solid #334155;padding-bottom:.75rem}.skill-count-text{color:#94a3b8;font-size:.9rem;margin:0}.skill-search-toolbar{display:flex;align-items:flex-end;gap:1rem;margin-bottom:1.5rem}.skill-search-box{flex:1;background:transparent;padding:0;border-radius:0;border:none}.skill-search-input{width:100%;padding:.75rem 1rem;background-color:#1e293b;border:1px solid #475569;border-radius:6px;color:#e2e8f0;font-size:.95rem;transition:all .2s ease}.skill-search-input::placeholder{color:#64748b}.skill-search-input:focus{outline:none;border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa1a}.create-skill-btn{background:linear-gradient(135deg,#10b981 0%,#059669 100%);color:#fff;padding:.75rem 1.5rem;border-radius:6px;border:none;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s;white-space:nowrap;height:fit-content}.create-skill-btn:hover{background:linear-gradient(135deg,#0da271 0%,#047857 100%);transform:translateY(-2px);box-shadow:0 4px 8px #0596694d}.create-skill-link{background:none;border:none;color:#60a5fa;font-weight:600;cursor:pointer;padding:0;text-decoration:underline;transition:color .2s}.create-skill-link:hover{color:#93c5fd}.skill-showing-info{color:#94a3b8;font-size:.8rem;margin-bottom:1rem;text-align:right}.no-skills-message{text-align:center;color:#94a3b8;padding:2rem;font-size:1rem}.no-skills-message button{background:none;border:none;color:#60a5fa;font-weight:600;cursor:pointer;padding:0;text-decoration:underline;transition:color .2s}.no-skills-message button:hover{color:#93c5fd}.skill-card-number{font-weight:700;color:#60a5fa;font-size:.8rem;margin-bottom:.5rem}.skill-card-content{flex:1;display:flex;flex-direction:column}.skill-card-title{font-size:1rem;color:#e2e8f0;margin:0 0 .5rem;line-height:1.3;font-weight:600}.skill-card-description{color:#cbd5e1;margin-bottom:.75rem;line-height:1.4;font-size:.85rem;flex-grow:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.skill-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.5rem}.skill-tag{display:inline-block;background-color:#334155;color:#cbd5e1;padding:.2rem .6rem;border-radius:12px;font-size:.7rem;font-weight:500;border:1px solid #475569}.skill-tag-more{display:inline-block;background-color:transparent;color:#94a3b8;padding:.2rem .6rem;font-size:.7rem;font-weight:500}.skill-card-meta{display:flex;align-items:center;gap:.5rem;margin:.5rem 0;padding-top:.75rem;border-top:1px solid #334155;flex-wrap:wrap;font-size:.8rem}.skill-source-link{color:#60a5fa;text-decoration:none;font-size:.8rem;font-weight:500;transition:color .2s}.skill-source-link:hover{color:#93c5fd;text-decoration:underline}.skill-downloads{color:#94a3b8;font-size:.8rem}.skill-card-footer{display:flex;justify-content:space-between;align-items:center;gap:.5rem;margin-top:auto;padding-top:.75rem;border-top:1px solid #334155}.favorite-btn{background:none;border:none;font-size:1.25rem;cursor:pointer;padding:.5rem;transition:transform .2s}.favorite-btn:hover{transform:scale(1.2)}.favorite-btn.favorited{transform:scale(1.1)}.skill-actions{display:flex;gap:.5rem;margin-left:auto}.error-message{background:#7c2d12;color:#fca5a5;padding:1rem;border-radius:8px;margin-bottom:1.5rem;border-left:4px solid #dc2626}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#1e293b;border-radius:8px;box-shadow:0 20px 60px #0009;border:1px solid #334155;width:90%;max-width:550px;max-height:85vh;overflow-y:auto;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.skill-create-modal{display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid #334155;background:#1e293b}.modal-header h2{margin:0;font-size:1.25rem;color:#e2e8f0;font-weight:600}.modal-close-btn{background:none;border:none;color:#94a3b8;font-size:1.25rem;cursor:pointer;padding:.4rem;display:flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;border-radius:4px;transition:all .2s}.modal-close-btn:hover{background:#334155;color:#e2e8f0}.modal-form{padding:1.25rem 1.5rem}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid #334155;background:#0f172a}.modal-footer .cancel-btn{background:#475569;color:#e2e8f0;padding:.65rem 1.2rem;font-size:.9rem}.modal-footer .cancel-btn:hover{background:#64748b}.modal-footer .submit-btn{background:linear-gradient(135deg,#10b981 0%,#059669 100%);color:#fff;padding:.65rem 1.2rem;font-size:.9rem}.modal-footer .submit-btn:hover{background:linear-gradient(135deg,#0da271 0%,#047857 100%);transform:translateY(-2px);box-shadow:0 4px 8px #0596694d}.App-footer{text-align:center;padding:1.5rem;background:#0f172a;color:#94a3b8;margin-top:auto;border-top:1px solid #334155}.App-footer p{margin-bottom:.5rem}.App-footer a{color:#60a5fa;text-decoration:none}.App-footer a:hover{text-decoration:underline}@media (max-width: 1024px){.skills-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.skills-grid{grid-template-columns:1fr}.form-actions{flex-direction:column;gap:1rem}.cancel-btn,.back-to-list{margin-left:0;margin-top:.5rem}.skill-card-footer{flex-wrap:wrap}.skill-actions{width:100%;justify-content:flex-start}.App-header h1{font-size:1.8rem}.skill-list-title h2{font-size:1.5rem}.skill-search-toolbar{flex-direction:column;align-items:stretch}.skill-search-box{padding:1rem}.create-skill-btn{width:100%;margin-top:0}.modal-content{width:95%;max-height:95vh}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e293b 0%,#0f172a 100%);padding:1rem}.login-box{width:100%;max-width:420px;background:#1e293b;border:1px solid #334155;border-radius:12px;padding:2rem;box-shadow:0 20px 60px #0009}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:2rem;margin-bottom:.5rem;color:#e2e8f0}.login-subtitle{font-size:.9rem;color:#94a3b8}.login-form{display:flex;flex-direction:column;gap:1rem}.login-form .form-group{display:flex;flex-direction:column;gap:.5rem}.login-form .form-group label{font-size:.95rem;color:#cbd5e1;font-weight:500}.login-form .form-group input{padding:.75rem;border:1px solid #475569;border-radius:8px;background:#0f172a;color:#e2e8f0;font-size:1rem;transition:all .3s ease}.login-form .form-group input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.login-form .form-group input:disabled{opacity:.6;cursor:not-allowed}.login-btn{padding:.9rem;margin-top:1rem;background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.login-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #3b82f64d}.login-btn:disabled{opacity:.7;cursor:not-allowed}.error-message{padding:.75rem;background:rgba(239,68,68,.1);border:1px solid #ef4444;border-radius:6px;color:#fca5a5;font-size:.9rem}.login-footer{text-align:center;margin-top:1.5rem}.toggle-btn{background:none;border:none;color:#3b82f6;cursor:pointer;font-size:.9rem;text-decoration:underline;padding:0;transition:color .3s ease}.toggle-btn:hover:not(:disabled){color:#2563eb}.toggle-btn:disabled{opacity:.6;cursor:not-allowed}.demo-info{margin-top:2rem;padding:1rem;background:rgba(59,130,246,.1);border:1px solid #3b82f6;border-radius:8px}.demo-title{font-size:.9rem;color:#cbd5e1;margin-bottom:.75rem;font-weight:600}.demo-accounts{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.demo-account{padding:.75rem;background:rgba(15,23,42,.5);border-radius:6px;font-size:.85rem}.demo-account strong{display:block;color:#3b82f6;margin-bottom:.5rem}.demo-account p{color:#94a3b8;margin:.25rem 0}.user-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:linear-gradient(135deg,#1e293b 0%,#0f172a 100%);border-bottom:1px solid #334155;box-shadow:0 4px 12px #0000004d}.user-info{display:flex;align-items:center;gap:1rem}.user-avatar{font-size:2rem}.user-details{display:flex;flex-direction:column;gap:.25rem}.user-name{font-size:1rem;font-weight:600;color:#e2e8f0}.user-role{font-size:.85rem;color:#94a3b8}.logout-btn{padding:.6rem 1.2rem;background:#ef4444;color:#fff;border:none;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .3s ease}.logout-btn:hover{background:#dc2626;transform:translateY(-2px)}.permission-denied{display:flex;align-items:center;justify-content:center;min-height:300px;padding:2rem}.permission-message{text-align:center;padding:2rem;background:rgba(239,68,68,.1);border:2px solid #ef4444;border-radius:8px;max-width:400px}.permission-message h3{font-size:1.5rem;color:#fca5a5;margin-bottom:1rem}.permission-message p{color:#cbd5e1;margin-bottom:.5rem}.pagination-container{display:flex;justify-content:center;align-items:center;gap:2rem;margin-top:2rem;padding:1.5rem;background:rgba(30,41,59,.5);border:1px solid #334155;border-radius:8px}.pagination-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);color:#fff;border:1px solid #1e40af;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease}.pagination-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 16px #3b82f64d;background:linear-gradient(135deg,#2563eb 0%,#1d4ed8 100%)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed;background:linear-gradient(135deg,#64748b 0%,#475569 100%)}.pagination-btn:active:not(:disabled){transform:translateY(0)}.pagination-prev,.pagination-next{min-width:120px}.pagination-info{font-size:1rem;font-weight:600;color:#e2e8f0;min-width:120px;text-align:center;background:rgba(59,130,246,.1);padding:.75rem 1rem;border-radius:6px;border:1px solid #3b82f6}@media (max-width: 768px){.pagination-container{gap:1rem;flex-wrap:wrap}.pagination-btn{padding:.6rem 1rem;font-size:.85rem}.pagination-prev,.pagination-next{min-width:auto}.pagination-info{min-width:auto;padding:.6rem .8rem;font-size:.9rem}}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;background-color:#f8fafc;color:#334155}#root{min-height:100vh}
