.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#17f,#0056d9);padding:1rem}.login-box{background:var(--surface);padding:2.5rem;border-radius:12px;box-shadow:var(--shadow-lg);width:100%;max-width:400px}.login-box h1{text-align:center;margin-bottom:.5rem;color:var(--text-primary)}.login-subtitle{text-align:center;color:var(--text-secondary);margin-bottom:2rem;font-size:.95rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary);font-size:.9rem}.form-group input{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:6px;font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a}.error-message{background-color:#fef2f2;color:var(--danger-color);padding:.75rem;border-radius:6px;margin-bottom:1rem;font-size:.9rem;border:1px solid #fecaca}.login-button{width:100%;background-color:var(--primary-color);color:#fff;padding:.875rem;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:background-color .2s}.login-button:hover{background-color:var(--primary-hover)}.login-hint{margin-top:1.5rem;padding:.75rem;background-color:#f8fafc;border-radius:6px;text-align:center;font-size:.85rem;color:var(--text-secondary)}.dashboard-container h1{margin-bottom:2rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2.5rem}.stat-card{background-color:var(--surface);padding:1.5rem;border-radius:8px;box-shadow:var(--shadow);border:1px solid var(--border-color);transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.stat-card h3{font-size:.875rem;font-weight:500;color:var(--text-secondary);margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.05em}.stat-number{font-size:2rem;font-weight:700;color:var(--primary-color)}.upcoming-section{background-color:var(--surface);padding:1.5rem;border-radius:8px;box-shadow:var(--shadow);border:1px solid var(--border-color)}.upcoming-section h2{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.upcoming-list{display:flex;flex-direction:column;gap:1rem}.upcoming-item{display:flex;align-items:flex-start;gap:1rem;padding:1rem;border-radius:6px;transition:background-color .2s}.upcoming-item:hover{background-color:var(--background)}.upcoming-icon{width:40px;height:40px;border-radius:8px;background:linear-gradient(135deg,#17f,#0056d9);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.25rem;flex-shrink:0}.upcoming-details{flex:1}.upcoming-details h4{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.upcoming-meta{display:flex;gap:1.5rem;font-size:.875rem;color:var(--text-secondary)}.upcoming-meta span{display:flex;align-items:center;gap:.375rem}@media(max-width:768px){.stats-grid{grid-template-columns:1fr}.upcoming-meta{flex-direction:column;gap:.5rem}}.rp-container{animation:fadeIn .3s ease-in-out}.user-grid-inputs{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}.rp-select{width:100%;padding:.75rem;border:1px solid var(--rp-border);border-radius:8px;font-size:1rem;background-color:#fff;color:var(--rp-text-main);cursor:pointer;transition:border-color .2s,box-shadow .2s}.rp-select:focus{outline:none;border-color:var(--rp-primary);box-shadow:0 0 0 3px #4f46e51a}.rp-select:disabled{background-color:#f1f5f9;cursor:not-allowed}.user-email-cell{color:var(--rp-text-muted);font-size:.9rem}.user-role-cell .role-badge{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0;text-transform:capitalize}.rp-modal-body{padding:1.5rem;background-color:#fff}.rp-input-group label small{font-weight:400;color:var(--rp-text-muted);margin-left:4px}.rp-loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;gap:1rem;color:var(--rp-text-muted)}.rp-spinner{width:40px;height:40px;border:3px solid var(--rp-border);border-top:3px solid var(--rp-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.role-actions-cell .rp-btn-text:hover{background:#dbeafe}.role-actions-cell .rp-btn-text-danger:hover{background:#fee2e2}@media(max-width:768px){.user-grid-inputs{grid-template-columns:1fr}.rp-page-header{flex-direction:column;align-items:flex-start;gap:1rem}.rp-btn-primary{width:100%}.rp-roles-table{display:block;overflow-x:auto}}.form-footer-info{margin-top:1rem;font-size:.8rem;color:var(--rp-text-muted);font-style:italic}.page-container h1{margin-bottom:.5rem}.page-description{color:var(--text-secondary);margin-bottom:2rem;font-size:1rem}.content-placeholder{background-color:var(--surface);padding:3rem 2rem;border-radius:8px;box-shadow:var(--shadow);border:1px solid var(--border-color);text-align:center}.content-placeholder p{color:var(--text-secondary);font-size:1rem}.file-input{display:none}.files-card{background-color:var(--surface);padding:2rem;border-radius:8px;box-shadow:var(--shadow);border:1px solid var(--border-color);animation:fadeIn .3s ease-in-out}.upload-section h2,.files-list-section h2{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem}.upload-area{border:2px dashed var(--border-color);border-radius:8px;padding:3rem 2rem;text-align:center;background-color:#4f46e505;cursor:pointer;transition:all .3s ease;margin-bottom:1.5rem}.upload-area:hover{border-color:var(--primary-color);background-color:#4f46e50d}.upload-icon{width:48px;height:48px;color:var(--primary-color);margin-bottom:1rem;stroke-width:1.5}.upload-content{margin-bottom:1.5rem}.upload-text{font-size:1rem;color:var(--text-primary);margin-bottom:.5rem}.upload-text strong{color:var(--primary-color)}.upload-subtext{font-size:.875rem;color:var(--text-secondary)}.browse-button{background-color:var(--primary-color);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease;margin-bottom:1rem}.browse-button:hover:not(:disabled){background-color:#4f46e5;transform:translateY(-2px);box-shadow:0 4px 12px #4f46e54d}.browse-button:disabled{opacity:.6;cursor:not-allowed}.selected-file{background-color:#f0f9ff;border:1px solid #bfdbfe;border-radius:8px;padding:1rem;margin-bottom:1rem;display:flex;justify-content:space-between;align-items:center;animation:slideInUp .3s ease-out}.file-info{display:flex;align-items:center;gap:1rem;flex:1}.file-icon{font-size:1.5rem}.file-details{display:flex;flex-direction:column;gap:.25rem}.file-name{font-size:.95rem;font-weight:500;color:var(--text-primary);margin:0;word-break:break-word}.file-size{font-size:.85rem;color:var(--text-secondary);margin:0}.remove-button{background-color:#fee2e2;color:#dc2626;border:none;width:32px;height:32px;border-radius:50%;font-size:1.2rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.remove-button:hover:not(:disabled){background-color:#fca5a5;transform:scale(1.1)}.remove-button:disabled{opacity:.5;cursor:not-allowed}.upload-button{width:100%;background-color:var(--primary-color);color:#fff;border:none;padding:.875rem 1.5rem;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.upload-button:hover:not(:disabled){background-color:#4f46e5;transform:translateY(-2px);box-shadow:0 4px 12px #4f46e54d}.upload-button:disabled{opacity:.6;cursor:not-allowed;background-color:var(--primary-color)}.files-list-section{margin-top:2.5rem;padding-top:2rem;border-top:1px solid var(--border-color)}.files-table{display:flex;flex-direction:column;gap:.5rem;border-radius:8px;overflow:hidden}.table-header{display:grid;grid-template-columns:2fr 1fr 1.5fr;gap:1rem;background-color:#f8fafc;padding:1rem;font-weight:600;color:var(--text-secondary);font-size:.875rem;text-transform:uppercase;letter-spacing:.05em;border:1px solid var(--border-color);border-bottom:none;border-radius:8px 8px 0 0}.table-row{display:grid;grid-template-columns:2fr 1fr 1.5fr;gap:1rem;padding:1rem;border:1px solid var(--border-color);border-top:none;background-color:#fff;transition:all .2s ease;align-items:center}.table-row:last-child{border-radius:0 0 8px 8px}.table-row:hover{background-color:#f9fafb;box-shadow:0 1px 3px #0000001a}.col{display:flex;align-items:center;gap:.75rem;font-size:.95rem;color:var(--text-primary);word-break:break-word}.col-name{font-weight:500}.col-size,.col-date{color:var(--text-secondary)}@media(max-width:768px){.files-card{padding:1.5rem}.upload-area{padding:2rem 1rem}.table-header,.table-row{grid-template-columns:1fr;gap:.5rem}.col:before{font-weight:600;color:var(--text-secondary);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.col-name:before{content:"File Name: "}.col-size:before{content:"Size: "}.col-date:before{content:"Uploaded: "}.selected-file{flex-direction:column;gap:1rem;align-items:flex-start}.remove-button{width:100%;border-radius:4px}}@media(prefers-color-scheme:dark){.selected-file{background-color:#4f46e51a;border-color:#4f46e54d}.table-header{background-color:#0003}.table-row{background-color:var(--surface)}.table-row:hover{background-color:#4f46e50d}}.prompts-card{background-color:var(--surface);padding:2rem;border-radius:8px;box-shadow:var(--shadow);border:1px solid var(--border-color);animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.input-section h2,.prompts-history-section h2{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem}.prompt-input-wrapper{position:relative;margin-bottom:1rem}.prompt-textarea{width:100%;padding:1rem;border:2px solid var(--border-color);border-radius:8px;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:.95rem;color:#000;background-color:#fff;resize:vertical;min-height:150px;max-height:400px;transition:all .2s ease;box-sizing:border-box}.prompt-textarea::placeholder{color:var(--text-secondary)}.prompt-textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #4f46e51a}.prompt-textarea:disabled{background-color:#f5f5f5;cursor:not-allowed;opacity:.6}.char-count{font-size:.75rem;color:var(--text-secondary);margin-top:.5rem;text-align:right}.button-group{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.submit-button{flex:1;min-width:150px;background-color:var(--primary-color);color:#fff;border:none;padding:.875rem 1.5rem;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.submit-button:hover:not(:disabled){background-color:#4f46e5;transform:translateY(-2px);box-shadow:0 4px 12px #4f46e54d}.submit-button:disabled{opacity:.6;cursor:not-allowed;background-color:var(--primary-color)}.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.clear-button{background-color:#f5f5f5;color:var(--text-primary);border:1px solid var(--border-color);padding:.875rem 1.5rem;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease}.clear-button:hover:not(:disabled){background-color:#e5e5e5;border-color:#999}.clear-button:disabled{opacity:.5;cursor:not-allowed}.prompt-info{background-color:#4f46e50d;border:1px solid rgba(79,70,229,.2);border-radius:6px;padding:1rem;margin-top:1rem}.prompt-info p{margin:0;font-size:.9rem;color:var(--text-primary)}.prompt-info strong{color:var(--primary-color)}.prompt-info kbd{background-color:#fff;border:1px solid var(--border-color);border-radius:3px;padding:.25rem .5rem;font-family:monospace;font-size:.85rem;box-shadow:0 1px 2px #0000001a}.prompts-history-section{margin-top:2.5rem;padding-top:2rem;border-top:1px solid var(--border-color)}.prompts-list-wrapper{margin-top:1rem;overflow-x:auto}.prompts-table{width:100%;border-collapse:collapse;background:transparent}.prompts-table thead th{text-align:left;padding:.75rem 1rem;font-size:.9rem;color:var(--text-secondary);border-bottom:1px solid var(--border-color)}.prompts-table tbody td{padding:.75rem 1rem;vertical-align:top;border-bottom:1px solid var(--border-color)}.prompt-preview{max-width:640px;white-space:pre-wrap;overflow:hidden;text-overflow:ellipsis}.actions-cell{display:flex;gap:.5rem}.action-button{padding:.4rem .6rem;border-radius:6px;border:1px solid var(--border-color);background:#fff;cursor:pointer;font-size:.85rem}.action-button.view{color:#065f46;border-color:#065f461f}.action-button.edit{color:#1d4ed8;border-color:#1d4ed81f}.action-button.delete{color:#b91c1c;border-color:#b91c1c14}.status-switch{position:relative;display:inline-block;width:44px;height:24px}.status-switch input{opacity:0;width:0;height:0}.switch-slider{position:absolute;cursor:pointer;inset:0;background-color:#ccc;transition:.2s;border-radius:24px}.switch-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.2s;border-radius:50%}.status-switch input:checked+.switch-slider{background-color:var(--primary-color)}.status-switch input:checked+.switch-slider:before{transform:translate(20px)}.prompts-list{display:flex;flex-direction:column;gap:1rem}.prompt-item{background-color:#f9fafb;border:1px solid var(--border-color);border-radius:8px;padding:1.5rem;transition:all .2s ease;animation:slideInUp .3s ease-out}@keyframes slideInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.prompt-item:hover{border-color:var(--primary-color);box-shadow:0 2px 8px #4f46e51a;background-color:#fff}.prompt-header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1rem}.prompt-icon{font-size:1.5rem;flex-shrink:0}.prompt-meta{flex:1}.prompt-timestamp{font-size:.85rem;color:var(--text-secondary);margin:0;font-weight:500}.prompt-text{color:var(--text-primary);font-size:.95rem;line-height:1.5;margin:0 0 1rem;word-break:break-word;white-space:pre-wrap;background-color:#fff;border-radius:4px;border-left:3px solid var(--primary-color);padding:.75rem .75rem .75rem 1rem}.delete-prompt-button{background-color:#fee2e2;color:#dc2626;border:1px solid #fca5a5;padding:.5rem 1rem;border-radius:4px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease}.delete-prompt-button:hover{background-color:#fca5a5;border-color:#dc2626;transform:translateY(-1px)}@media(max-width:768px){.prompts-card{padding:1.5rem}.prompt-textarea{font-size:.9rem;min-height:120px}.button-group{flex-direction:column}.submit-button,.clear-button{width:100%;min-width:unset}.prompt-item{padding:1rem}.prompt-header{gap:.75rem}.prompt-text{font-size:.9rem}}@media(prefers-color-scheme:dark){.prompt-textarea{background-color:#fff;color:#000}.prompt-textarea:focus{box-shadow:0 0 0 3px #4f46e533}.clear-button{background-color:#ffffff1a}.clear-button:hover:not(:disabled){background-color:#ffffff26}.prompt-info{background-color:#4f46e51a;border-color:#4f46e54d}.prompt-item{background-color:#0003}.prompt-item:hover{background-color:#4f46e50d}.prompt-text{background-color:#0000004d}.prompt-info kbd{background-color:#0000004d;border-color:#fff3}}.profile-container h1{margin-bottom:2rem}.profile-content{max-width:900px}.profile-header{background-color:var(--surface);padding:2rem;border-radius:8px;box-shadow:var(--shadow);border:1px solid var(--border-color);display:flex;align-items:center;gap:1.5rem;margin-bottom:2rem}.profile-avatar-large{width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,#17f,#0056d9);display:flex;align-items:center;justify-content:center;color:#fff;font-size:3rem;flex-shrink:0}.profile-header-info h2{margin-bottom:.5rem}.profile-role{color:var(--text-secondary);font-size:1rem}.profile-details{background-color:var(--surface);padding:2rem;border-radius:8px;box-shadow:var(--shadow);border:1px solid var(--border-color);margin-bottom:2rem}.profile-details h3{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.profile-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.profile-info-item{display:flex;align-items:flex-start;gap:1rem}.info-icon{width:40px;height:40px;border-radius:8px;background-color:var(--background);display:flex;align-items:center;justify-content:center;color:var(--primary-color);font-size:1.25rem;flex-shrink:0}.info-content{flex:1}.info-content label{display:block;font-size:.875rem;font-weight:500;color:var(--text-secondary);margin-bottom:.25rem}.info-content p{font-size:1rem;color:var(--text-primary);font-weight:500}.profile-additional{background-color:var(--surface);padding:2rem;border-radius:8px;box-shadow:var(--shadow);border:1px solid var(--border-color)}.profile-additional h3{margin-bottom:1rem}.profile-bio{color:var(--text-secondary);line-height:1.6;margin-bottom:1.5rem}.profile-meta{padding-top:1rem;border-top:1px solid var(--border-color);font-size:.875rem;color:var(--text-secondary)}@media(max-width:768px){.profile-header{flex-direction:column;text-align:center}.profile-info-grid{grid-template-columns:1fr}}.sidebar{width:260px;background-color:var(--sidebar-bg);height:100vh;position:fixed;left:0;top:0;overflow-y:auto;box-shadow:var(--shadow)}.sidebar-header{padding:1.5rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-header h2{color:#fff;font-size:1.25rem;font-weight:600}.sidebar-nav{padding:1rem 0}.nav-item{display:flex;align-items:center;padding:.875rem 1.25rem;color:#ffffffb3;text-decoration:none;transition:all .2s;border-left:3px solid transparent}.nav-item:hover{background-color:var(--sidebar-hover);color:#fff}.nav-item.active{background-color:var(--sidebar-hover);color:#fff;border-left-color:var(--primary-color)}.nav-icon{font-size:1.25rem;margin-right:.875rem;display:flex;align-items:center}.nav-label{font-weight:500;font-size:.95rem}@media(max-width:768px){.sidebar{transform:translate(-100%);transition:transform .3s}.sidebar.open{transform:translate(0)}}.nav-group{display:flex;flex-direction:column}.group-header{cursor:pointer;justify-content:space-between}.nav-arrow{margin-left:auto;display:flex;align-items:center}.sub-menu{background:#0003;margin-bottom:5px}.sub-nav-item{display:block;padding:.6rem 1.25rem .6rem 3.5rem;background-color:var(--sidebar-bg);color:#fff9;text-decoration:none;font-size:.875rem;transition:all .2s}.sub-nav-item:hover,.sub-nav-item.active{color:#fff;background:#ffffff0d}.topbar{background-color:var(--surface);border-bottom:1px solid var(--border-color);padding:1rem 2rem;box-shadow:var(--shadow)}.topbar-content{display:flex;justify-content:space-between;align-items:center}.topbar-left h2{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.topbar-right{position:relative}.profile-trigger{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.5rem;border-radius:6px;transition:background-color .2s}.profile-trigger:hover{background-color:var(--background)}.user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#17f,#0056d9);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.25rem}.dropdown-arrow{font-size:1.125rem;color:var(--text-secondary);transition:transform .2s}.dropdown-arrow.open{transform:rotate(180deg)}.profile-dropdown{position:absolute;top:calc(100% + .5rem);right:0;background-color:var(--surface);border:1px solid var(--border-color);border-radius:8px;box-shadow:var(--shadow-lg);min-width:220px;overflow:hidden;z-index:1000}.dropdown-header{padding:1rem;border-bottom:1px solid var(--border-color)}.dropdown-user-info{display:flex;flex-direction:column}.dropdown-name{font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.dropdown-email{font-size:.875rem;color:var(--text-secondary)}.dropdown-divider{height:1px;background-color:var(--border-color)}.dropdown-item{width:100%;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:none;border:none;color:var(--text-primary);font-size:.95rem;cursor:pointer;transition:background-color .2s;text-align:left}.dropdown-item:hover{background-color:var(--background)}.dropdown-item.logout{color:var(--danger-color);border-top:1px solid var(--border-color)}.dropdown-item.logout:hover{background-color:#fef2f2}@media(max-width:768px){.topbar{padding:1rem}.topbar-left h2{font-size:1rem}}.layout{display:flex;min-height:100vh;background-color:var(--background)}.main-content{flex:1;display:flex;flex-direction:column;margin-left:260px}.page-content{flex:1;padding:2rem;overflow-y:auto}@media(max-width:768px){.main-content{margin-left:0}.page-content{padding:1rem}}:root{--rp-primary: #4f46e5;--rp-primary-hover: #4338ca;--rp-bg: #f8fafc;--rp-border: #e2e8f0;--rp-text-main: #1e293b;--rp-text-muted: #64748b}.rp-container{padding:2rem;font-family:Inter,system-ui,sans-serif;color:var(--rp-text-main)}.rp-page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.rp-title-section h1{font-size:1.875rem;margin:0 0 .5rem}.rp-title-section p{color:var(--rp-text-muted);margin:0}.rp-action-group{display:flex;gap:12px}.rp-btn{padding:.625rem 1.25rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;border:1px solid transparent}.rp-btn-primary{background:var(--rp-primary);color:#fff}.rp-btn-primary:hover{background:var(--rp-primary-hover)}.rp-btn-secondary{background:#fff;color:var(--rp-primary);border-color:var(--rp-primary)}.rp-btn-secondary:hover{background:#f5f3ff}.rp-btn-link{background:none;border:none;color:var(--rp-text-muted);cursor:pointer}.rp-content-card{background:#fff;border:1px solid var(--rp-border);border-radius:12px;min-height:300px;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 3px #0000001a}.rp-empty-state{color:var(--rp-text-muted)}.rp-modal-overlay{position:fixed;inset:0;background:#0f172ab3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.rp-modal-card{background:#fff;width:100%;max-width:600px;border-radius:16px;box-shadow:0 25px 50px -12px #00000040;max-height:90vh;display:flex;flex-direction:column}.rp-modal-header{padding:1rem;border-bottom:1px solid var(--rp-border);display:flex;justify-content:space-between;align-items:center}.rp-close-x{background:none;border:none;font-size:2rem;cursor:pointer;color:var(--rp-text-muted)}.rp-modal-body{max-height:60vh;overflow-y:auto;padding:15px}.rp-input-group{margin-bottom:1.5rem}.rp-input-group label{display:block;font-weight:600;margin-bottom:.5rem}.rp-input-group input{width:100%;padding:.75rem;border:1px solid var(--rp-border);border-radius:8px;font-size:1rem}.rp-help-text{display:block;font-size:.875rem;color:var(--rp-text-muted);margin-top:.5rem}.rp-matrix-container label{display:block;font-weight:600;margin-bottom:1rem}.rp-matrix-container{max-height:50vh;overflow-y:auto;padding:1rem;border:1px solid #e0e0e0;border-radius:6px}.rp-table{width:100%;border-collapse:collapse}.rp-table thead{position:sticky;top:0;background-color:#f5f5f5;z-index:10}.rp-table th,.rp-table td{padding:12px;text-align:left;border-bottom:1px solid #e0e0e0;white-space:nowrap}.rp-module-label{min-width:200px;max-width:200px;word-wrap:break-word;white-space:normal}.rp-table th{font-weight:600;color:#333;background-color:#f5f5f5}.rp-table tbody tr:hover{background-color:#fafafa}.rp-text-center{text-align:center}.rp-modal-footer{padding:1.25rem 1.5rem;border-top:1px solid var(--rp-border);display:flex;justify-content:flex-end;gap:1rem;background:#f8fafc;border-bottom-left-radius:16px;border-bottom-right-radius:16px}.rp-matrix-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.rp-matrix-header label{margin-bottom:0}.rp-bulk-actions{display:flex;align-items:center;gap:8px}.rp-btn-text{background:none;border:1px solid var(--rp-primary);color:var(--rp-primary);font-size:.813rem;font-weight:600;padding:5px;cursor:pointer}.rp-divider{color:var(--rp-border);font-size:.8rem}.rp-permissions-table{width:100%;border-collapse:collapse;background:#fff}.rp-permissions-table thead{background-color:#f5f5f5;border-bottom:2px solid var(--rp-border)}.rp-permissions-table th{padding:1rem;text-align:left;font-weight:600;color:var(--rp-text-main);font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.rp-permissions-table tbody tr{border-bottom:1px solid var(--rp-border);transition:background-color .2s}.rp-permissions-table tbody tr:hover{background-color:#f8fafc}.rp-permissions-table td{padding:1rem;color:var(--rp-text-main)}.rp-permissions-table td:last-child{display:flex;gap:.5rem;align-items:center}.rp-permissions-table button{padding:.5rem 1rem;border-radius:6px;border:1px solid transparent;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.rp-permissions-table button:first-of-type{background-color:#dbeafe;color:#0369a1;border-color:#0369a1}.rp-permissions-table button:first-of-type:hover{background-color:#bfdbfe;border-color:#0369a1}.rp-permissions-table button:last-of-type{background-color:#fee2e2;color:#dc2626;border-color:#dc2626}.rp-permissions-table button:last-of-type:hover{background-color:#fecaca;border-color:#dc2626}.rp-content-card{padding:2rem}.rp-content-card p{text-align:center;color:var(--rp-text-muted)}.btn-edit{background:#e0f2fe!important;color:#0369a1!important;border:1px solid #bae6fd!important}.btn-delete{background:#fee2e2!important;color:#dc2626!important;border:1px solid #fecaca!important}.listing-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;background:transparent!important;border:none!important;box-shadow:none!important}.role-item-card{background:#fff;padding:1.5rem;border-radius:12px;border:1px solid var(--rp-border);display:flex;justify-content:space-between;align-items:center;transition:transform .2s}.role-item-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000000d}.role-info h3{margin:0 0 .25rem;font-size:1.1rem}.role-info p{margin:0;font-size:.875rem;color:var(--rp-text-muted)}.rp-roles-table{width:100%;border-collapse:collapse;background:#fff}.rp-roles-table thead{background-color:#f5f5f5;border-bottom:2px solid var(--rp-border)}.rp-roles-table th{padding:1rem;text-align:left;font-weight:600;color:var(--rp-text-main);font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.rp-roles-table tbody tr{border-bottom:1px solid var(--rp-border);transition:background-color .2s}.rp-roles-table tbody tr:hover{background-color:#f8fafc}.rp-roles-table tbody tr.deleting-row{opacity:.6}.rp-roles-table td{padding:1rem;color:var(--rp-text-main)}.role-name-cell{font-weight:500}.role-badge{display:inline-block;background:#dbeafe;color:#0369a1;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:600}.role-actions-cell{display:flex;gap:.75rem;align-items:center}.rp-btn-text{background:#e0f2fe;color:#0369a1;border:1px solid #bae6fd;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.rp-btn-text:hover:not(:disabled){background:#bfdbfe;border-color:#0369a1}.rp-btn-text:disabled{opacity:.5;cursor:not-allowed}.rp-btn-text-danger{background:#fee2e2;color:#dc2626;border:1px solid #fecaca;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.rp-btn-text-danger:hover:not(:disabled){background:#fecaca;border-color:#dc2626}.rp-btn-text-danger:disabled{opacity:.5;cursor:not-allowed}*{margin:0;padding:0;box-sizing:border-box}: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;--primary-color: #1177ff;--primary-hover: #0056d9;--secondary-color: #64748b;--success-color: #10b981;--danger-color: #ef4444;--background: #f8fafc;--surface: #ffffff;--border-color: #e2e8f0;--text-primary: #0f172a;--text-secondary: #64748b;--sidebar-bg: #0d47a1;--sidebar-hover: #1565c0;--shadow: 0 1px 3px 0 rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1);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:var(--background);color:var(--text-primary)}h1,h2,h3,h4,h5,h6{line-height:1.2;font-weight:600;color:var(--text-primary)}h1{font-size:1.875rem}h2{font-size:1.5rem}h3{font-size:1.25rem}button{border-radius:6px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s}button:focus,button:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}input,textarea{font-family:inherit;font-size:1em}a{color:var(--primary-color);text-decoration:none}
