*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background:linear-gradient(135deg,#1a1a2e,#16213e);min-height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#ffffff0d}::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff4d}::selection{background:#667eea80;color:#fff}:focus-visible{outline:2px solid #667eea;outline-offset:2px}a{color:inherit;text-decoration:none}button{font-family:inherit;font-size:inherit;cursor:pointer}input,select,textarea{font-family:inherit;font-size:inherit}.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}.btn-primary{padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;cursor:pointer;font-weight:600;transition:transform .2s,box-shadow .2s}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-secondary{padding:.75rem 1.5rem;background:transparent;border:1px solid rgba(255,255,255,.2);border-radius:10px;color:#fff;cursor:pointer;font-weight:500;transition:background .2s}.btn-secondary:hover{background:#ffffff1a}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-danger{padding:.75rem 1.5rem;background:#ef44441a;border:1px solid #ef4444;border-radius:10px;color:#ef4444;cursor:pointer;font-weight:500;transition:background .2s}.btn-danger:hover{background:#ef444433}.btn-action{padding:.375rem .75rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#fff;font-size:.85rem;cursor:pointer;text-decoration:none;transition:background .2s}.btn-action:hover{background:#ffffff26}.btn-action:disabled{opacity:.5;cursor:not-allowed}.btn-action.edit{color:#667eea;border-color:#667eea66;background:#667eea1a}.btn-action.edit:hover{background:#667eea33}.btn-action.delete{color:#ef4444;border-color:#ef444466;background:#ef44441a}.btn-action.delete:hover{background:#ef444433}.btn-action.add{color:#22c55e;border-color:#22c55e66;background:#22c55e1a}.btn-action.add:hover{background:#22c55e33}.btn-search{padding:.75rem 1.5rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:10px;color:#fff;cursor:pointer;transition:background .2s}.btn-search:hover{background:#ffffff26}.modal-overlay{position:fixed;inset:0;background:#000000b3;backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:1000}.modal{width:100%;max-width:500px;max-height:90vh;overflow-y:auto;background:#1a1a2e;border-radius:16px;border:1px solid rgba(255,255,255,.1);padding:2rem;box-shadow:0 20px 40px #0006;color:#fff}.modal h2{margin:0 0 1.5rem;font-size:1.5rem;font-weight:600}.modal.modal-wide{max-width:900px;width:90%;height:85vh;max-height:85vh;display:flex;flex-direction:column}.modal.modal-wide form{display:flex;flex-direction:column;flex:1;min-height:0;overflow-y:auto}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.1)}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#fffc;font-size:.9rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;box-sizing:border-box;transition:border-color .2s,box-shadow .2s}.form-group input::placeholder,.form-group select::placeholder,.form-group textarea::placeholder{color:#fff6}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea33}.form-group input option,.form-group select option,.form-group textarea option{background:#1a1a2e;color:#fff}.form-group textarea{resize:vertical;min-height:100px}.form-row{display:flex;gap:1rem}.form-row .form-group{flex:1}.tag-badge{display:inline-block;padding:.25rem .6rem;border-radius:12px;font-size:.75rem;font-weight:500;color:#fff;background:#6b7280;text-shadow:0 1px 2px rgba(0,0,0,.2)}.pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1.5rem}.pagination button{padding:.5rem 1rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;cursor:pointer;transition:background .2s}.pagination button:hover:not(:disabled){background:#ffffff26}.pagination button:disabled{opacity:.5;cursor:not-allowed}.pagination span{color:#fff9}.spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.1);border-top-color:#667eea;border-radius:50%;margin:0 auto 1rem;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.btn-sm{padding:.4rem .8rem;font-size:.85rem}
