.loading-container{display:flex;justify-content:center;align-items:center;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.spinner{font-size:1.5rem;color:#fff}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.login-card{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;padding:3rem;width:100%;max-width:400px;text-align:center}.login-header h1{color:#333;font-size:1.75rem;margin-bottom:.5rem}.login-header p{color:#666;margin-bottom:2rem}.login-button{display:inline-flex;align-items:center;gap:.75rem;background:#0078d4;color:#fff;border:none;padding:.75rem 2rem;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;width:100%;justify-content:center}.login-button:hover:not(:disabled){background:#106ebe;transform:translateY(-2px);box-shadow:0 4px 12px #0078d44d}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-icon{width:20px;height:20px}.login-footer{margin-top:2rem;font-size:.875rem;color:#999}.user-profile{display:flex;align-items:center;gap:1rem;padding:.5rem 1rem;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.user-info{display:flex;align-items:center;gap:.75rem;flex:1}.user-icon{width:32px;height:32px;color:#667eea}.user-details{display:flex;flex-direction:column}.user-name{font-weight:600;color:#333}.user-role,.user-custom-role{font-size:.875rem;color:#666}.logout-button{background:#dc3545;color:#fff;border:none;padding:.5rem;border-radius:6px;cursor:pointer;transition:background .3s ease}.logout-button:hover{background:#c82333}.logout-icon{width:18px;height:18px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}#root{min-height:100vh}.app-container{min-height:100vh;padding:20px}.content-wrapper{max-width:800px;margin:0 auto;background:#fff;border-radius:20px;box-shadow:0 20px 40px #0000001a;overflow:hidden;animation:slideUp .6s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.header{background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff}.header-content{padding:30px;text-align:center}.header h1{font-size:2rem;margin-bottom:10px;font-weight:300}.header p{opacity:.9;font-size:1.1rem}.main-content{padding:40px}.config-section{background:#f8fafc;border-radius:12px;padding:25px;margin-bottom:30px;border-left:4px solid #4f46e5}.section-header{display:flex;align-items:center;gap:10px;margin-bottom:20px}.section-header h2{color:#1e293b;font-size:1.5rem;margin:0}.section-icon{width:24px;height:24px}.add-icon{color:#10b981}.delete-icon{color:#ef4444}.form-section{margin-bottom:40px;padding-bottom:30px;border-bottom:2px solid #e2e8f0}.form-section:first-child{padding-top:0}.form-section:last-child{border-bottom:none;margin-bottom:0}.form-content{padding-top:10px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:25px}@media (max-width: 768px){.form-grid{grid-template-columns:1fr}}.form-group{display:flex;flex-direction:column}.form-group label{display:block;margin-bottom:8px;color:#374151;font-weight:500;font-size:.9rem}.form-input{width:100%;padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:16px;transition:all .3s ease;background:#fff;color:#374151}.form-input:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a;transform:translateY(-1px)}.form-input::placeholder{color:#9ca3af}.form-hint{font-size:.8rem;color:#6b7280;margin-top:4px}.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px;position:relative;overflow:hidden;text-decoration:none}.btn:hover{transform:translateY(-2px)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 4px 14px #10b9814d}.btn-success:hover:not(:disabled){box-shadow:0 10px 20px #10b98166}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 4px 14px #ef44444d}.btn-danger:hover:not(:disabled){box-shadow:0 10px 20px #ef444466}.btn-icon{width:18px;height:18px}.btn-spinner{width:18px;height:18px;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.alert{display:flex;align-items:center;gap:12px;padding:16px 20px;border-radius:8px;font-weight:500;animation:slideDown .3s ease-out;border-left:4px solid}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.alert-success{background:#ecfdf5;color:#065f46;border-left-color:#10b981}.alert-error{background:#fef2f2;color:#991b1b;border-left-color:#ef4444}.alert-icon{width:20px;height:20px;flex-shrink:0}.result-data{background:#f1f5f9;border-radius:8px;padding:20px;border-left:4px solid #64748b}.result-data h4{color:#334155;margin-bottom:10px;font-size:1rem}.result-data pre{background:#1e293b;color:#e2e8f0;padding:15px;border-radius:6px;overflow-x:auto;font-size:14px;line-height:1.4;font-family:Courier New,monospace}.mt-4{margin-top:1rem}.space-y-3>*+*{margin-top:.75rem}@media (max-width: 640px){.app-container{padding:10px}.header-content{padding:20px}.header h1{font-size:1.5rem}.main-content,.config-section{padding:20px}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}#root{max-width:100%;margin:0 auto;text-align:center;width:100%}
