:root{--primary-color: #0f172a;--primary-hover: #1e293b;--primary-light: #334155;--secondary-color: #475569;--secondary-hover: #334155;--secondary-light: #64748b;--accent-color: #0ea5e9;--accent-hover: #0284c7;--success-color: #059669;--success-hover: #047857;--success-light: #10b981;--warning-color: #d97706;--warning-hover: #b45309;--warning-light: #f59e0b;--error-color: #dc2626;--error-hover: #b91c1c;--error-light: #ef4444;--info-color: #0ea5e9;--info-hover: #0284c7;--info-light: #38bdf8;--white: #ffffff;--gray-50: #f8fafc;--gray-100: #f1f5f9;--gray-200: #e2e8f0;--gray-300: #cbd5e1;--gray-400: #94a3b8;--gray-500: #64748b;--gray-600: #475569;--gray-700: #334155;--gray-800: #1e293b;--gray-900: #0f172a;--font-size-normal: 14px;--font-size-label: 13px;--font-size-title: 18px;--font-size-subtitle: 16px;--font-weight-light: 300;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.625;--padding-vertical: 6px;--padding-horizontal: 12px;--border-radius: 6px;--border-width: 1px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 16px;--spacing-xl: 24px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--transition-fast: .15s ease;--transition-normal: .3s ease;--transition-slow: .5s ease}body{font-size:var(--font-size-normal);font-weight:var(--font-weight-normal);line-height:var(--line-height-normal);color:var(--gray-700);background-color:var(--white);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.text-normal{font-size:var(--font-size-normal);font-weight:var(--font-weight-normal);line-height:var(--line-height-normal);color:var(--gray-700)}.text-label{font-size:var(--font-size-label);font-weight:var(--font-weight-medium);line-height:var(--line-height-tight);color:var(--gray-600);text-transform:uppercase;letter-spacing:.025em}.text-title{font-size:var(--font-size-title);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);color:var(--gray-800);margin-bottom:var(--spacing-sm)}.text-subtitle{font-size:var(--font-size-subtitle);font-weight:var(--font-weight-medium);line-height:var(--line-height-normal);color:var(--gray-700);margin-bottom:var(--spacing-xs)}.text-strong{font-weight:var(--font-weight-semibold);color:var(--gray-800)}.text-light{font-weight:var(--font-weight-light);color:var(--gray-500)}.text-error{font-size:var(--font-size-label);font-weight:var(--font-weight-medium);color:var(--error-color);margin-top:var(--spacing-xs);display:block}.btn{padding:calc(var(--padding-vertical) + 2px) calc(var(--padding-horizontal) + 8px);border-radius:var(--border-radius);border:var(--border-width) solid transparent;font-size:var(--font-size-normal);font-weight:var(--font-weight-medium);line-height:var(--line-height-normal);cursor:pointer;transition:all var(--transition-fast);text-decoration:none;display:inline-block;text-align:center;box-shadow:var(--shadow-sm)}.btn-primary{background-color:var(--primary-color);color:var(--white);border-color:var(--primary-color)}.btn-primary:hover{background-color:var(--primary-hover);border-color:var(--primary-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-secondary{background-color:var(--secondary-color);color:var(--white);border-color:var(--secondary-color)}.btn-secondary:hover{background-color:var(--secondary-hover);border-color:var(--secondary-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-outline{background-color:transparent;color:var(--primary-color);border-color:var(--primary-color)}.btn-outline:hover{background-color:var(--primary-color);color:var(--white)}.btn-full{width:100%;box-sizing:border-box}.form-input{padding:calc(var(--padding-vertical) + 4px) var(--padding-horizontal);border:var(--border-width) solid var(--gray-300);border-radius:var(--border-radius);font-size:var(--font-size-normal);line-height:var(--line-height-normal);background-color:var(--white);color:var(--gray-700);transition:all var(--transition-fast);box-shadow:var(--shadow-sm);width:100%;box-sizing:border-box}.form-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #0ea5e91a;background-color:var(--gray-50)}.form-input::placeholder{color:var(--gray-400);font-weight:var(--font-weight-normal)}.form-label{font-size:var(--font-size-label);font-weight:var(--font-weight-medium);color:var(--gray-600);margin-bottom:var(--spacing-xs);display:block;text-transform:uppercase;letter-spacing:.025em}.card{background-color:var(--white);border:var(--border-width) solid var(--gray-200);border-radius:var(--border-radius);box-shadow:var(--shadow-sm);padding:var(--spacing-xl);margin-bottom:var(--spacing-lg);transition:all var(--transition-normal)}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-header{border-bottom:var(--border-width) solid var(--gray-200);padding-bottom:var(--spacing-md);margin-bottom:var(--spacing-md)}.card-title{font-size:var(--font-size-title);font-weight:var(--font-weight-semibold);color:var(--gray-800);margin:0}.card-subtitle{font-size:var(--font-size-subtitle);font-weight:var(--font-weight-medium);color:var(--gray-600);margin:var(--spacing-xs) 0 0 0}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-lg)}.container-fluid{width:100%;padding:0 var(--spacing-lg)}@media(max-width:768px){.container,.container-fluid{padding:0 var(--spacing-md)}.card{padding:var(--spacing-lg);margin-bottom:var(--spacing-md);margin-top:var(--spacing-lg)}.btn{padding:calc(var(--padding-vertical) + 6px) calc(var(--padding-horizontal) + 12px);font-size:var(--font-size-normal);min-height:44px}.form-input{padding:calc(var(--padding-vertical) + 8px) var(--padding-horizontal);font-size:var(--font-size-normal);min-height:44px;width:100%}.form-label{font-size:var(--font-size-normal);margin-bottom:var(--spacing-sm)}.text-title{font-size:var(--font-size-subtitle);margin-bottom:var(--spacing-md)}}@media(max-width:480px){.container,.container-fluid{padding:0 var(--spacing-sm)}.card{padding:var(--spacing-md);margin-bottom:var(--spacing-sm);margin-top:var(--spacing-md);max-width:100%}.text-title{font-size:var(--font-size-subtitle);margin-bottom:var(--spacing-sm)}.btn{padding:calc(var(--padding-vertical) + 8px) calc(var(--padding-horizontal) + 16px);font-size:var(--font-size-normal);min-height:48px;width:100%}.form-input{padding:calc(var(--padding-vertical) + 10px) var(--padding-horizontal);font-size:var(--font-size-normal);min-height:48px;width:100%}.form-label{font-size:var(--font-size-normal);margin-bottom:var(--spacing-sm)}.mb-3{margin-bottom:var(--spacing-md)}.mb-4{margin-bottom:var(--spacing-lg)}}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mb-0{margin-bottom:0}.mb-1{margin-bottom:var(--spacing-xs)}.mb-2{margin-bottom:var(--spacing-sm)}.mb-3{margin-bottom:var(--spacing-md)}.mb-4{margin-bottom:var(--spacing-lg)}.mb-5{margin-bottom:var(--spacing-xl)}.mt-0{margin-top:0}.mt-1{margin-top:var(--spacing-xs)}.mt-2{margin-top:var(--spacing-sm)}.mt-3{margin-top:var(--spacing-md)}.mt-4{margin-top:var(--spacing-lg)}.mt-5{margin-top:var(--spacing-xl)}.p-0{padding:0}.p-1{padding:var(--spacing-xs)}.p-2{padding:var(--spacing-sm)}.p-3{padding:var(--spacing-md)}.p-4{padding:var(--spacing-lg)}.p-5{padding:var(--spacing-xl)}.header{position:fixed;top:0;left:0;right:0;background-color:var(--primary-color);color:var(--white);padding:var(--spacing-md) 0;box-shadow:var(--shadow-md);z-index:1000}.header-content{display:flex;justify-content:space-between;align-items:center}.header-brand h1{color:var(--white);margin:0;font-weight:var(--font-weight-bold);text-shadow:0 1px 2px rgba(0,0,0,.3)}.header-nav{display:flex;align-items:center;gap:var(--spacing-lg)}.user-dropdown{position:relative}.user-avatar{display:flex;align-items:center;gap:var(--spacing-xs);background:none;border:none;color:var(--white);cursor:pointer;padding:var(--spacing-xs);border-radius:var(--border-radius);transition:all var(--transition-fast)}.user-avatar:hover{background-color:#ffffff1a}.avatar-circle{width:32px;height:32px;background-color:var(--accent-color);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--white);font-size:14px}.dropdown-arrow{font-size:12px;color:var(--white);transition:transform var(--transition-fast)}.user-avatar.active .dropdown-arrow{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:100%;right:0;background-color:var(--white);border:var(--border-width) solid var(--gray-200);border-radius:var(--border-radius);box-shadow:var(--shadow-lg);min-width:280px;z-index:1000;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all var(--transition-fast)}.dropdown-menu.show{opacity:1;visibility:visible;transform:translateY(0)}.dropdown-header{padding:var(--spacing-lg);border-bottom:var(--border-width) solid var(--gray-200)}.user-info .user-name{font-size:var(--font-size-subtitle);font-weight:var(--font-weight-semibold);color:var(--gray-800);margin-bottom:var(--spacing-xs);text-shadow:none}.user-info .user-email{font-size:var(--font-size-normal);color:var(--gray-600);margin-bottom:var(--spacing-sm)}.user-role{display:flex;gap:var(--spacing-xs)}.role-badge{background-color:var(--accent-color);color:var(--white);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius);font-size:var(--font-size-label);font-weight:var(--font-weight-medium);text-transform:uppercase}.dropdown-divider{height:1px;background-color:var(--gray-200);margin:0}.dropdown-logout{padding:var(--spacing-sm)}.dropdown-item{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-sm) var(--spacing-md);background:none;border:none;color:var(--gray-700);font-size:var(--font-size-normal);cursor:pointer;border-radius:var(--border-radius);transition:all var(--transition-fast)}.dropdown-item:hover{background-color:var(--gray-100);color:var(--error-color)}.logout-btn:hover{background-color:var(--error-color);color:var(--white)}.navbar{position:fixed;top:70px;left:0;right:0;background-color:var(--white);border-bottom:var(--border-width) solid var(--gray-200);box-shadow:var(--shadow-sm);z-index:999}.navbar-content{display:flex;justify-content:center;align-items:center;padding:var(--spacing-sm) 0}.navbar-menu{display:flex;align-items:center;gap:var(--spacing-lg)}.navbar-link{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);color:var(--gray-600);text-decoration:none;border-radius:var(--border-radius);transition:all var(--transition-fast);font-size:var(--font-size-normal);font-weight:var(--font-weight-medium)}.navbar-link:hover{background-color:var(--gray-100);color:var(--primary-color)}.navbar-link.active{background-color:var(--primary-color);color:var(--white)}.navbar-link i{font-size:14px}.navbar-dropdown{position:relative}.navbar-dropdown-toggle{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);color:var(--gray-600);background:none;border:none;border-radius:var(--border-radius);transition:all var(--transition-fast);font-size:var(--font-size-normal);font-weight:var(--font-weight-medium);cursor:pointer}.navbar-dropdown-toggle:hover{background-color:var(--gray-100);color:var(--primary-color)}.navbar-dropdown-toggle.active{background-color:var(--primary-color);color:var(--white)}.navbar-dropdown-toggle i{font-size:14px}.navbar-dropdown-toggle .dropdown-arrow{font-size:12px;transition:transform var(--transition-fast)}.navbar-dropdown-toggle.active .dropdown-arrow{transform:rotate(180deg)}.navbar-dropdown-menu{position:absolute;top:100%;left:0;background-color:var(--white);border:var(--border-width) solid var(--gray-200);border-radius:var(--border-radius);box-shadow:var(--shadow-lg);min-width:200px;z-index:1000;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all var(--transition-fast)}.navbar-dropdown-menu.show{opacity:1;visibility:visible;transform:translateY(0)}.navbar-dropdown-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);color:var(--gray-600);text-decoration:none;transition:all var(--transition-fast);font-size:var(--font-size-normal);font-weight:var(--font-weight-normal)}.navbar-dropdown-item:hover{background-color:var(--gray-50);color:var(--primary-color)}.navbar-dropdown-item i{font-size:14px;width:16px;text-align:center}.footer{background-color:var(--gray-100);padding:var(--spacing-lg) 0;margin-top:auto}.footer-content{display:flex;justify-content:space-between;align-items:center}.dashboard-body{display:flex;flex-direction:column;min-height:100vh;padding-top:120px}.main-content{flex:1;padding:var(--spacing-xl) 0}.dashboard-welcome{margin-bottom:var(--spacing-xl)}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-lg);margin-top:var(--spacing-lg)}.stat-card{background-color:var(--gray-50);border:var(--border-width) solid var(--gray-200);border-radius:var(--border-radius);padding:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-md);transition:all var(--transition-normal)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-icon{background-color:var(--accent-color);color:var(--white);width:48px;height:48px;border-radius:var(--border-radius);display:flex;align-items:center;justify-content:center;font-size:20px}.stat-info h3{margin:0 0 var(--spacing-xs) 0}.stat-info p{margin:0;color:var(--gray-600)}.table-container{overflow-x:auto;border-radius:var(--border-radius)}.table{width:100%;border-collapse:collapse;background-color:var(--white)}.table th{background-color:var(--gray-100);color:var(--gray-800);font-weight:var(--font-weight-semibold);padding:var(--spacing-md);text-align:left;border-bottom:var(--border-width) solid var(--gray-200);font-size:var(--font-size-normal)}.table td{padding:var(--spacing-md);border-bottom:var(--border-width) solid var(--gray-200);font-size:var(--font-size-normal);color:var(--gray-700)}.table-striped tbody tr:nth-child(odd){background-color:var(--gray-50)}.table tbody tr:hover{background-color:var(--gray-100)}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:var(--border-width) solid var(--gray-200)}.page-title h1{margin:0 0 var(--spacing-xs) 0}.page-title p{margin:0;color:var(--gray-600)}.page-actions{display:flex;gap:var(--spacing-sm)}.action-buttons{display:flex;gap:var(--spacing-xs)}.btn-sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-label)}.role-badge{background-color:var(--accent-color);color:var(--white);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius);font-size:var(--font-size-label);font-weight:var(--font-weight-medium);text-transform:uppercase;margin-right:var(--spacing-xs)}.permission-badge{background-color:var(--secondary-color);color:var(--white);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius);font-size:var(--font-size-label);font-weight:var(--font-weight-medium);margin-right:var(--spacing-xs);margin-bottom:var(--spacing-xs);display:inline-block}.modal{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;opacity:0;visibility:hidden;transition:all var(--transition-normal)}.modal.show{opacity:1;visibility:visible}.modal-content{background-color:var(--white);border-radius:var(--border-radius);box-shadow:var(--shadow-lg);max-width:500px;width:90%;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:var(--border-width) solid var(--gray-200)}.modal-header h2{margin:0}.modal-close{background:none;border:none;font-size:18px;color:var(--gray-500);cursor:pointer;padding:var(--spacing-xs);border-radius:var(--border-radius);transition:all var(--transition-fast)}.modal-close:hover{background-color:var(--gray-100);color:var(--gray-700)}.modal-body{padding:var(--spacing-lg)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-lg);border-top:var(--border-width) solid var(--gray-200)}.form-group{margin-bottom:var(--spacing-lg)}.form-group:last-child{margin-bottom:0}.alert{padding:var(--spacing-md);border-radius:var(--border-radius);margin-bottom:var(--spacing-lg);border:var(--border-width) solid}.alert-success{background-color:var(--success-light);color:var(--success-color);border-color:var(--success-color)}.checkbox-group{display:flex;flex-wrap:wrap;gap:var(--spacing-md)}.checkbox-label{display:flex;align-items:center;gap:var(--spacing-xs);cursor:pointer;font-size:var(--font-size-normal)}.checkbox-label input[type=checkbox]{margin:0}.form-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end;margin-top:var(--spacing-lg);padding-top:var(--spacing-md);border-top:1px solid var(--border-color)}.permission-groups{display:flex;flex-direction:column;gap:var(--spacing-lg)}.permission-group{border:1px solid var(--border-color);border-radius:var(--border-radius);padding:var(--spacing-md);background-color:var(--gray-50)}.permission-group h4{margin:0 0 var(--spacing-sm) 0;color:var(--gray-700);font-weight:var(--font-weight-semibold)}.permission-item{margin-bottom:var(--spacing-xs)}.user-info{display:flex;flex-direction:column;gap:var(--spacing-sm)}.info-item{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-normal)}.info-item strong{color:var(--gray-700);min-width:120px}.permission-direct{background-color:var(--accent-color)!important;position:relative}.permission-role{background-color:var(--secondary-color)!important}.permission-badge i{margin-left:var(--spacing-xs);font-size:10px}.permissions-summary .permission-group{margin-bottom:var(--spacing-md)}.permission-list{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.form-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm);margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:var(--border-width) solid var(--gray-200)}
