:root{--brand-purple: #7c3aed;--brand-purple-dark: #5b21b6;--brand-purple-mid: #6d28d9;--brand-blue: #2563eb;--brand-blue-dark: #1d4ed8;--brand-gradient: linear-gradient(135deg, #7c3aed 0%, #2563eb 100%);--brand-gradient-soft:linear-gradient(135deg, #ede9fe 0%, #dbeafe 100%);--color-primary: #7c3aed;--color-primary-dark: #5b21b6;--color-primary-light: #ede9fe;--color-primary-mid: #8b5cf6;--color-danger: #dc2626;--color-danger-light: #fef2f2;--color-success: #16a34a;--color-success-light: #f0fdf4;--color-warning: #d97706;--color-warning-light: #fffbeb;--text-heading: #1e1b4b;--text-body: #374151;--text-muted: #6b7280;--text-subtle: #9ca3af;--surface-base: #f5f3ff;--surface-card: #ffffff;--surface-header: #fafafa;--border-light: #ede9fe;--border-normal: #e5e7eb;--border-medium: #d1d5db;--shadow-card: 0 1px 4px rgba(124, 58, 237, .07);--shadow-card2: 0 2px 8px rgba(124, 58, 237, .08), 0 1px 2px rgba(0,0,0,.04);--shadow-elevated: 0 4px 24px rgba(124, 58, 237, .13);--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 14px;--font-xs: .75rem;--font-sm: .875rem;--font-base: 1rem;--font-lg: 1.125rem;--font-xl: 1.25rem;--font-2xl: 1.5rem;--font-3xl: 1.75rem;--page-title-size: 1.6rem}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:Segoe UI,Inter,system-ui,-apple-system,sans-serif;font-size:16px;color:var(--text-heading);background:var(--surface-base)}a{text-decoration:none}h1,h2,h3,h4,h5,h6{margin:0;font-weight:700}input,button,select,textarea{font-family:inherit}.table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.search-input{padding:.4rem .75rem;border:1px solid var(--border-normal);border-radius:var(--radius-md);font-size:.875rem;outline:none;transition:border-color .15s;max-width:260px;width:100%}.search-input:focus{border-color:var(--color-primary)}.page-header-block{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.empty-state-panel{display:flex;flex-direction:column;align-items:center;gap:.6rem;padding:3.5rem 2rem;text-align:center;color:var(--text-muted)}.empty-state-panel__icon{font-size:2.5rem;line-height:1;margin-bottom:.25rem}.empty-state-panel__title{font-size:1.05rem;font-weight:700;color:var(--text-body);margin:0}.empty-state-panel__subtitle{font-size:.9rem;margin:0;max-width:360px;line-height:1.5}@keyframes shimmer-global{to{background-position:-200% 0}}.shimmer{background:linear-gradient(90deg,#f5f3ff 25%,#ede9fe 50%,#f5f3ff 75%);background-size:200% 100%;animation:shimmer-global 1.4s infinite;border-radius:4px}@media (max-width: 767px){.form-row{grid-template-columns:1fr!important}.dialog__actions{flex-direction:column}.table-wrapper{border-radius:0}.page-header-block{flex-direction:column;align-items:flex-start}.search-input{max-width:100%}}.module-page{padding:0}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.page-header__left{display:flex;flex-direction:column;gap:.2rem;min-width:0}.page-header__right{display:flex;align-items:center;gap:.625rem;flex-shrink:0;flex-wrap:wrap}.page-title{font-size:var(--page-title-size);font-weight:700;color:var(--text-heading);margin:0 0 .2rem;line-height:1.25}.page-subtitle{font-size:var(--font-sm);color:var(--text-muted);margin:0;line-height:1.5}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.375rem;padding:.5rem 1rem;border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:600;cursor:pointer;border:1px solid transparent;transition:background .15s,color .15s,border-color .15s,opacity .15s,transform .1s;white-space:nowrap;text-decoration:none;line-height:1.4;-webkit-user-select:none;user-select:none}.btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.btn:disabled,.btn[disabled]{opacity:.5;cursor:not-allowed;pointer-events:none}.btn:not(:disabled):active{transform:scale(.97)}.btn--lg{padding:.625rem 1.375rem;font-size:var(--font-base);border-radius:var(--radius-md)}.btn--sm{padding:.375rem .75rem;font-size:.8125rem;border-radius:var(--radius-sm)}.btn--xs{padding:.25rem .625rem;font-size:.75rem;border-radius:var(--radius-sm)}.btn--icon{padding:.4rem;min-width:2rem;min-height:2rem}.btn--primary{background:var(--brand-gradient);color:#fff;border-color:var(--brand-purple)}.btn--primary:not(:disabled):hover{background:linear-gradient(135deg,#5b21b6 0%,#1d4ed8 100%);border-color:var(--brand-purple-dark)}.btn--secondary{background:var(--surface-header);color:var(--text-body);border-color:var(--border-normal)}.btn--secondary:not(:disabled):hover{background:var(--border-normal)}.btn--ghost{background:transparent;color:var(--color-primary);border-color:transparent}.btn--ghost:not(:disabled):hover{background:var(--color-primary-light)}.btn--outline{background:var(--color-primary-light);color:var(--color-primary);border-color:#c4b5fd}.btn--outline:not(:disabled):hover{background:#ddd6fe}.btn--danger{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.btn--danger:not(:disabled):hover{background:#c62828;border-color:#c62828}.btn--danger-outline{background:var(--color-danger-light);color:var(--color-danger);border-color:#ef9a9a}.btn--danger-outline:not(:disabled):hover{background:#ffcdd2}.btn--success{background:var(--color-success);color:#fff;border-color:var(--color-success)}.btn--success:not(:disabled):hover{background:#1b5e20;border-color:#1b5e20}.btn--warning{background:var(--color-warning);color:#fff;border-color:var(--color-warning)}.btn--warning:not(:disabled):hover{background:#e65100;border-color:#e65100}.btn-spinner{width:.875rem;height:.875rem;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:btn-spin .65s linear infinite;flex-shrink:0}.btn--secondary .btn-spinner,.btn--ghost .btn-spinner,.btn--outline .btn-spinner{border-color:#1976d240;border-top-color:var(--color-primary)}@keyframes btn-spin{to{transform:rotate(360deg)}}.card{background:var(--surface-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-card2);overflow:hidden}.card--flat{box-shadow:none;border:1px solid var(--border-normal)}.card__header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:1rem 1.25rem;border-bottom:1px solid var(--border-light);background:var(--surface-header)}.card__title{font-size:var(--font-base);font-weight:700;color:var(--text-heading);margin:0}.card__subtitle{font-size:var(--font-xs);color:var(--text-muted);margin:.125rem 0 0}.card__body{padding:1.25rem}.card__footer{padding:.75rem 1.25rem;border-top:1px solid var(--border-light);background:var(--surface-header)}.data-table{width:100%;border-collapse:collapse;font-size:var(--font-sm)}.data-table thead tr{background:var(--surface-header);border-bottom:1px solid var(--border-normal)}.data-table th{padding:.625rem .875rem;text-align:left;font-size:.7rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.data-table td{padding:.75rem .875rem;color:var(--text-body);border-bottom:1px solid var(--border-light);vertical-align:middle}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover td{background:#faf5ff}.data-table .col-actions{text-align:right;white-space:nowrap}.data-table .col-number{font-family:monospace;font-size:.8125rem}.form-card{background:var(--surface-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-card2);padding:1.5rem;margin-bottom:1.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem 1.25rem;margin-bottom:1rem}.form-row--single{grid-template-columns:1fr}.form-row--three{grid-template-columns:1fr 1fr 1fr}.form-field{display:flex;flex-direction:column;gap:.3rem}.form-field--full{grid-column:1 / -1}.label{font-size:.8125rem;font-weight:600;color:var(--text-body)}.label--required:after{content:" *";color:var(--color-danger)}.input,.select-input{padding:.5rem .75rem;border:1px solid var(--border-medium);border-radius:var(--radius-md);font-size:var(--font-sm);color:var(--text-heading);background:var(--surface-card);width:100%;transition:border-color .15s,box-shadow .15s;appearance:none}.input:focus,.select-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #7c3aed1f}.input::placeholder{color:var(--text-subtle)}.input--error{border-color:var(--color-danger)!important;box-shadow:0 0 0 3px #e539351f!important}.input--readonly{background:var(--surface-header);color:var(--text-muted);cursor:default}.input--readonly:focus{border-color:var(--border-medium);box-shadow:none}textarea.input{resize:vertical;min-height:100px}.field-error{font-size:.75rem;color:var(--color-danger);margin:0;display:block}.field-hint{font-size:.75rem;color:var(--text-muted);margin:0;display:block}.form-divider{border:none;border-top:1px solid var(--border-light);margin:1.25rem 0}.form-section-title{font-size:var(--font-sm);font-weight:700;color:var(--text-heading);margin:0 0 .75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-light)}.form-actions{display:flex;align-items:center;justify-content:flex-end;gap:.625rem;padding-top:1rem;border-top:1px solid var(--border-light);margin-top:1.25rem}.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .6rem;border-radius:999px;font-size:.72rem;font-weight:600;white-space:nowrap;border:1px solid transparent}.badge__dot{width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}.badge--primary{background:var(--color-primary-light);color:var(--color-primary);border-color:#c4b5fd}.badge--success{background:var(--color-success-light);color:var(--color-success);border-color:#a5d6a7}.badge--danger{background:var(--color-danger-light);color:var(--color-danger);border-color:#ef9a9a}.badge--warning{background:var(--color-warning-light);color:var(--color-warning);border-color:#ffcc80}.badge--neutral{background:var(--surface-header);color:var(--text-muted);border-color:var(--border-normal)}.badge--active{background:var(--color-success-light);color:var(--color-success);border-color:#a5d6a7}.badge--inactive{background:var(--surface-header);color:var(--text-muted);border-color:var(--border-normal)}.badge--pending{background:var(--color-warning-light);color:var(--color-warning);border-color:#ffcc80}.badge--error{background:var(--color-danger-light);color:var(--color-danger);border-color:#ef9a9a}.status-badge{display:inline-block;padding:.2rem .6rem;border-radius:999px;font-size:.78rem;font-weight:600;white-space:nowrap}.status-badge--active{background:var(--color-success-light);color:var(--color-success)}.status-badge--inactive{background:var(--color-danger-light);color:var(--color-danger)}.status-badge--pending{background:var(--color-warning-light);color:var(--color-warning)}.role-chip{display:inline-block;padding:.2rem .6rem;background:#ede7f6;color:#4527a0;border-radius:999px;font-size:.78rem;font-weight:600}.error-banner{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.125rem;background:var(--color-danger-light);border:1px solid #ef9a9a;border-radius:var(--radius-md);color:#7f1d1d;font-size:var(--font-sm);margin-bottom:1.25rem}.error-banner__icon{font-size:1.1rem;flex-shrink:0}.error-banner__msg{flex:1;margin:0}.success-banner{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.125rem;background:var(--color-success-light);border:1px solid #a5d6a7;border-radius:var(--radius-md);color:#1b5e20;font-size:var(--font-sm);margin-bottom:1.25rem}.info-banner{display:flex;align-items:flex-start;gap:.625rem;padding:.875rem 1.125rem;background:var(--color-primary-light);border:1px solid #90caf9;border-radius:var(--radius-md);color:#0d47a1;font-size:var(--font-sm);margin-bottom:1.25rem;line-height:1.5}.empty-state{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:3.5rem 2rem;text-align:center;color:var(--text-muted)}.empty-state__icon{font-size:2.5rem;line-height:1;margin-bottom:.25rem}.empty-state__title{font-size:1.0625rem;font-weight:700;color:var(--text-body);margin:0}.empty-state__subtitle{font-size:var(--font-sm);margin:0;max-width:360px;line-height:1.5}.tab-bar{display:flex;gap:0;border-bottom:2px solid var(--border-normal);margin-bottom:1.5rem;overflow-x:auto}.tab-btn{padding:.625rem 1.125rem;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;font-size:var(--font-sm);font-weight:600;color:var(--text-muted);cursor:pointer;white-space:nowrap;transition:color .15s,border-color .15s}.tab-btn:hover{color:var(--text-body)}.tab-btn--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.dialog-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:900;display:flex;align-items:center;justify-content:center;padding:1rem;animation:backdrop-in .15s ease}@keyframes backdrop-in{0%{opacity:0}to{opacity:1}}.dialog{background:var(--surface-card);border-radius:var(--radius-xl);box-shadow:0 8px 40px #0000002e;width:100%;max-width:520px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;animation:dialog-in .18s ease}.dialog--lg{max-width:760px}.dialog--xl{max-width:960px}.dialog--sm{max-width:400px}@keyframes dialog-in{0%{opacity:0;transform:translateY(-12px) scale(.98)}to{opacity:1;transform:none}}.dialog__header{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;padding:1.25rem 1.5rem 1rem;border-bottom:1px solid var(--border-light);flex-shrink:0}.dialog__title{font-size:var(--font-lg);font-weight:700;color:var(--text-heading);margin:0}.dialog__subtitle{font-size:var(--font-sm);color:var(--text-muted);margin:.25rem 0 0}.dialog__close{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:1.25rem;padding:.1rem;line-height:1;border-radius:var(--radius-sm);flex-shrink:0;transition:color .15s,background .15s}.dialog__close:hover{color:var(--text-body);background:var(--surface-header)}.dialog__body{padding:1.25rem 1.5rem;overflow-y:auto;flex:1}.dialog__footer,.dialog__actions{padding:1rem 1.5rem;border-top:1px solid var(--border-light);display:flex;align-items:center;justify-content:flex-end;gap:.625rem;flex-shrink:0;background:var(--surface-header)}.spinner{width:1.75rem;height:1.75rem;border:3px solid var(--border-normal);border-top-color:var(--color-primary);border-radius:50%;animation:spin-global .7s linear infinite;flex-shrink:0}.spinner--sm{width:1rem;height:1rem;border-width:2px}.spinner--lg{width:2.5rem;height:2.5rem}@keyframes spin-global{to{transform:rotate(360deg)}}.loading-state{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:3.75rem 1.25rem;color:var(--text-muted);font-size:var(--font-sm)}.pagination{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1rem;border-top:1px solid var(--border-light);flex-wrap:wrap}.pagination__info{font-size:.8125rem;color:var(--text-muted)}.pagination__controls{display:flex;align-items:center;gap:.25rem}.page-btn{display:inline-flex;align-items:center;justify-content:center;min-width:2rem;height:2rem;padding:0 .4rem;border:1px solid var(--border-normal);border-radius:var(--radius-sm);background:var(--surface-card);color:var(--text-body);font-size:.8125rem;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s}.page-btn:hover:not(:disabled):not(.page-btn--active){background:var(--surface-header);border-color:var(--border-medium)}.page-btn--active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.page-btn:disabled{opacity:.4;cursor:not-allowed}.table-toolbar{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--border-light);gap:.75rem;flex-wrap:wrap}.table-count{font-size:.78rem;color:var(--text-subtle);font-weight:600;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.action-group{display:inline-flex;align-items:center;gap:.375rem}.btn-action{display:inline-flex;align-items:center;gap:.25rem;padding:.3rem .65rem;border:1.5px solid;border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s}.btn-action--edit{color:var(--color-primary);border-color:#c4b5fd;background:var(--color-primary-light)}.btn-action--edit:hover{background:#ddd6fe}.btn-action--delete{color:var(--color-danger);border-color:#ef9a9a;background:var(--color-danger-light)}.btn-action--delete:hover{background:#ffcdd2}.btn-action--view{color:var(--color-success);border-color:#a5d6a7;background:var(--color-success-light)}.btn-action--view:hover{background:#c8e6c9}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background:var(--surface-card);border-radius:var(--radius-lg);padding:1rem 1.125rem;box-shadow:var(--shadow-card);display:flex;align-items:center;gap:.875rem;border-left:4px solid transparent}.stat-card__icon{font-size:1.4rem;flex-shrink:0}.stat-card__value{font-size:1.5rem;font-weight:700;color:var(--text-heading);line-height:1.1}.stat-card__label{font-size:.72rem;color:var(--text-muted);font-weight:500;margin-top:.1rem}.stat-card--blue{border-left-color:var(--brand-blue)}.stat-card--green{border-left-color:var(--color-success)}.stat-card--red{border-left-color:var(--color-danger)}.stat-card--orange{border-left-color:var(--color-warning)}.stat-card--purple{border-left-color:var(--brand-purple)}.row-count{padding:.5rem 1rem;font-size:.8rem;color:var(--text-subtle);border-top:1px solid var(--border-light)}.filter-bar{display:flex;align-items:center;gap:.625rem;margin-bottom:1.25rem;flex-wrap:wrap}.filter-bar__search{position:relative;display:flex;align-items:center;flex:1;min-width:200px}.filter-bar__search-icon{position:absolute;left:.625rem;font-size:.875rem;color:var(--text-subtle);pointer-events:none}.filter-bar__input{width:100%;padding:.475rem 2rem;border:1px solid var(--border-medium);border-radius:var(--radius-md);font-size:var(--font-sm);color:var(--text-heading);background:var(--surface-card);transition:border-color .15s,box-shadow .15s;outline:none}.filter-bar__input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #7c3aed1a}.filter-bar__clear{position:absolute;right:.5rem;background:none;border:none;cursor:pointer;color:var(--text-subtle);font-size:.875rem;padding:2px 4px;border-radius:4px;line-height:1}.filter-bar__clear:hover{color:var(--text-body);background:var(--surface-header)}.filter-bar__group{display:flex;gap:3px;background:var(--surface-header);border-radius:var(--radius-md);padding:3px;border:1px solid var(--border-normal)}.filter-btn{padding:.3rem .875rem;border:none;border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;cursor:pointer;background:transparent;color:var(--text-muted);transition:background .15s,color .15s;white-space:nowrap}.filter-btn:hover:not(.filter-btn--active){color:var(--text-body)}.filter-btn--active{background:var(--surface-card);color:var(--text-heading);box-shadow:0 1px 3px #00000014}@media (max-width: 767px){.page-header{flex-direction:column;align-items:flex-start;gap:.75rem;margin-bottom:1.25rem}.page-header__right{width:100%}.form-row,.form-row--three{grid-template-columns:1fr!important}.dialog{max-width:100%;border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-height:95vh}.dialog-backdrop{align-items:flex-end;padding:0}.dialog__actions,.dialog__footer{flex-direction:column-reverse}.dialog__actions .btn,.dialog__footer .btn{width:100%;justify-content:center}.stats-grid{grid-template-columns:1fr 1fr}.filter-bar{flex-direction:column;align-items:stretch}.filter-bar__search{min-width:unset}.pagination{flex-direction:column;align-items:flex-start;gap:.5rem}}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr}}
