a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:100vw;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:0}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Arial,sans-serif;background:#f4f4f4;height:100vh;display:flex;overflow:hidden;color:#333}#root{flex:1;display:flex;flex-direction:column}.left,.right{flex:1;padding:20px;min-height:0;overflow-y:auto}.left{background:#f4f4f4;display:flex;flex-direction:column;align-items:center;max-width:40%}.right{background:#fff;border-left:1px solid #ccc;display:flex;flex-direction:column;max-width:60%}h1{margin-bottom:20px;font-size:1.6rem;color:#222}form{background:#fff;padding:20px;border-radius:10px;box-shadow:0 2px 8px #00000014;width:100%;max-width:600px;display:flex;flex-direction:column;gap:12px}form>div{width:100%}label{font-weight:600;display:block;margin-bottom:4px}input,textarea,select{width:100%;max-width:100%;min-width:100%;padding:10px;border:1px solid #ccc;border-radius:6px;font-size:14px;background:#fff;box-sizing:border-box}textarea{overflow:hidden;resize:none;min-height:10vh;max-height:60vh}.search-bar select,#moduleSelect,select{max-width:unset;min-width:unset;display:flex;flex:1}.search-bar button{background:none}button{background:#007bff;color:#fff;border:none;padding:10px 15px;border-radius:6px;cursor:pointer;transition:background .2s}button:hover{background:#0056b3}.toolbar{display:flex;gap:10px;align-items:center}.required{color:red}.muted{color:#666;font-size:12px}.roles-box{display:flex;flex-direction:column;gap:6px;margin-top:4px}.roles-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.roles-list{display:flex;flex-wrap:wrap;gap:8px}.roles-list label{font-weight:400;background:#f0f0f0;padding:4px 8px;border-radius:6px;cursor:pointer;text-align:center}.search{display:flex;padding:10px;border-bottom:1px solid #ddd;align-items:center;gap:10px;position:sticky;top:0;z-index:2}.search-bar{display:flex;gap:8px;align-items:center;flex-wrap:nowrap;flex-direction:row}.search-bar select{min-width:150px}.search-bar input,.search-bar select{padding:8px;border-radius:6px;border:1px solid #ccc}.search-bar.search-left{flex:1}.search-bar.search-right{flex:0}.search-bar button{background:none;transition:transform .3s}.search-bar button:hover{transform:translateY(-1px) rotate(180deg)}@keyframes rotate360{0%{transform:translateY(-1px) rotate(0)}to{transform:translateY(-1px) rotate(360deg)}}.search-bar button.animate-rotate{animation:rotate360 .5s forwards}.list-container{flex:1;overflow-y:auto;padding:15px 0}.item{border-bottom:1px solid #eee;padding:12px 10px;background:#fff;border-radius:6px;margin-bottom:10px;box-shadow:0 1px 4px #0000000d;transition:transform .1s,box-shadow .1s}.item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.item:last-child{border-bottom:none}.field{margin:4px 0}.actions{margin-top:6px;display:flex;gap:8px;align-items:center;margin-bottom:6px}.actions button{display:flex;align-items:center;gap:6px;padding:6px;font-size:14px;background:#fff;color:#333;cursor:pointer;transition:border-color .2s,transform .1s}.actions button:hover{transform:translateY(-1px)}.edit-btn i{color:#28a745}.delete-btn i{color:#dc3545}#refreshBtn i{color:#007bff}.drag-handle{display:inline-flex;align-items:center;justify-content:center;font-size:18px;cursor:grab;color:#666;padding:4px;-webkit-user-select:none;user-select:none;transition:color .2s,transform .1s}.drag-handle:hover{color:#333}.drag-handle:active{cursor:grabbing;transform:scale(1.1)}.actions i{font-size:16px;display:inline-flex}@media(max-width:900px){body{flex-direction:column}.left,.right{flex:unset;width:100%;max-width:100%;height:50vh}}
