:root{--color-primary:#0179a5;--color-primary-dark:#005676;--color-primary-light:#0090c4;--color-primary-50:#e0f1f7;--color-primary-100:#b3def0;--color-primary-200:#80c6e0;--color-secondary:#ed3231;--color-secondary-dark:#c21a1a;--color-secondary-light:#f16867;--color-secondary-50:#ffebee;--color-orange:#fe9100;--color-orange-dark:#cc7400;--color-orange-light:#ffa833;--color-orange-50:#fff5e6;--color-pink:#f02975;--color-bg:#f8fafc;--color-white:#fff;--color-gray-50:#f8fafc;--color-gray-100:#f1f5f9;--color-gray-200:#e2e8f0;--color-gray-300:#cbd5e1;--color-gray-400:#94a3b8;--color-gray-500:#64748b;--color-gray-600:#475569;--color-gray-700:#334155;--color-gray-800:#1e293b;--color-gray-900:#0f172a;--border-color:#e2e8f0;--border-color-light:#f1f5f9;--color-success:#10b981;--color-success-bg:#ecfdf5;--color-warning:#f59e0b;--color-warning-bg:#fffbeb;--color-error:#ef4444;--color-error-bg:#fef2f2;--color-info:#3b82f6;--color-info-bg:#eff6ff;--font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs:.6875rem;--font-size-sm:.75rem;--font-size-base:.875rem;--font-size-md:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--font-size-4xl:2.25rem;--font-weight-light:300;--font-weight-regular:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--font-weight-extrabold:800;--line-height-tight:1.25;--line-height-normal:1.5;--line-height-relaxed:1.625;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-2xl:20px;--radius-full:9999px;--shadow-xs:0 1px 2px #0000000a;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 6px -1px #00000012, 0 2px 4px -2px #0000000d;--shadow-lg:0 10px 15px -3px #00000014, 0 4px 6px -4px #0000000d;--shadow-xl:0 20px 25px -5px #00000014, 0 8px 10px -6px #0000000a;--shadow-card:0 1px 3px #0000000d, 0 1px 2px #00000008;--shadow-card-hover:0 8px 25px #00000014, 0 4px 10px #0000000a;--shadow-sidebar:2px 0 8px #0000000f;--shadow-dropdown:0 10px 40px #0000001f;--sidebar-width:260px;--sidebar-collapsed-width:72px;--header-height:64px;--content-max-width:1920px;--transition-fast:.15s ease;--transition-base:.2s ease;--transition-slow:.3s ease;--transition-spring:.3s cubic-bezier(.34, 1.56, .64, 1);--z-sidebar:100;--z-header:200;--z-dropdown:300;--z-modal-overlay:400;--z-modal:500;--z-toast:600;--z-tooltip:700}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:16px}body{font-family:var(--font-family);font-size:var(--font-size-base);font-weight:var(--font-weight-regular);line-height:var(--line-height-normal);color:var(--color-gray-800);background-color:var(--color-bg);overflow-x:hidden}img{max-width:100%;height:auto;display:block}a{color:var(--color-primary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-primary-light)}button{cursor:pointer;font-family:var(--font-family);background:0 0;border:none;outline:none}input,select,textarea{font-family:var(--font-family);font-size:var(--font-size-base)}ul,ol{list-style:none}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);color:var(--color-gray-900)}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}h4{font-size:var(--font-size-lg)}h5{font-size:var(--font-size-md)}h6{font-size:var(--font-size-base)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{transform:scale(1.05)}70%{transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes ripple{to{opacity:0;transform:scale(4)}}@keyframes countUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.app-layout{background:var(--color-bg);min-height:100vh;display:flex}.app-main{margin-left:var(--sidebar-width);min-height:100vh;transition:margin-left var(--transition-slow);flex-direction:column;flex:1;display:flex}.app-main.sidebar-collapsed{margin-left:var(--sidebar-collapsed-width)}.app-content{padding:var(--space-8);padding-top:calc(var(--header-height) + var(--space-8));max-width:var(--content-max-width);flex:1;width:100%}.sidebar{width:var(--sidebar-width);color:#fffc;z-index:var(--z-sidebar);transition:width var(--transition-slow);background:#011d29;border-right:1px solid #ffffff14;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden}.sidebar.collapsed{width:var(--sidebar-collapsed-width)}.sidebar-logo{border-bottom:1px solid #ffffff14;justify-content:center;align-items:center;min-height:76px;padding:14px 18px;display:flex;background:#011d29!important}.logo-badge{background:#fff;border-radius:12px;justify-content:center;align-items:center;width:100%;padding:8px 16px;display:flex;box-shadow:0 4px 12px #00000026}.logo-badge img{object-fit:contain;width:auto;max-height:40px}.sidebar-nav{padding:var(--space-3) 0;flex:1;overflow-y:auto}.sidebar-section{padding:var(--space-2) var(--space-4);margin-top:var(--space-2)}.sidebar-section-title{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.08em;color:#fff6;padding:var(--space-1) var(--space-3);margin-bottom:var(--space-1)}.sidebar-item{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:#ffffffb3;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none;margin-bottom:1px;text-decoration:none;display:flex;position:relative}.sidebar-item:hover{color:var(--color-white);background:#ffffff0f}.sidebar-item.active{background:var(--color-primary);color:var(--color-white);box-shadow:none}.sidebar-item .icon{flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.sidebar-item .label{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.sidebar-item .chevron{width:16px;height:16px;transition:transform var(--transition-fast);opacity:.6}.sidebar-item .chevron.open{transform:rotate(90deg)}.sidebar-sub-items{max-height:0;transition:max-height var(--transition-slow);border-left:none;margin-top:4px;margin-bottom:4px;margin-left:36px;padding-left:0;overflow:hidden}.sidebar-sub-items.open{max-height:500px}.sidebar-sub-item{align-items:center;gap:var(--space-2);color:#ffffffa6;font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast);border-left:2px solid #0000;margin-bottom:2px;padding:6px 12px;text-decoration:none;display:flex;position:relative}.sidebar-sub-item:hover{color:var(--color-white);border-left-color:#fff3}.sidebar-sub-item.active{color:var(--color-primary-light);border-left-color:var(--color-primary-light);font-weight:600}.sidebar-sub-item:before{display:none!important}.sidebar-footer{padding:var(--space-3) 0;background:#011d29;border-top:1px solid #ffffff14;margin-top:auto}.logout-item{text-align:left;width:100%;transition:all var(--transition-fast);background:0 0;justify-content:flex-start;align-items:center;display:flex;color:#ef4444!important}.logout-item:hover{color:#ff6b6b!important;background:#ef44441a!important}.sidebar-item .chevron{opacity:.5;width:16px;height:16px;transition:transform var(--transition-fast);margin-left:auto}.header{top:0;right:0;left:var(--sidebar-width);height:var(--header-height);background:var(--color-white);border-bottom:1px solid var(--border-color);padding:0 var(--space-8);z-index:var(--z-header);transition:left var(--transition-slow);justify-content:space-between;align-items:center;display:flex;position:fixed}.header.sidebar-collapsed{left:var(--sidebar-collapsed-width)}.header-left{align-items:center;gap:var(--space-4);display:flex}.header-welcome{flex-direction:column;display:flex}.header-welcome h2{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900)}.header-welcome p{font-size:var(--font-size-sm);color:var(--color-gray-500)}.header-center{max-width:420px;margin:0 var(--space-6);flex:1}.header-search{width:100%;position:relative}.header-search input{width:100%;padding:var(--space-2) var(--space-4);padding-left:var(--space-10);border:1px solid var(--border-color);border-radius:var(--radius-full);background:var(--color-gray-50);font-size:var(--font-size-base);color:var(--color-gray-700);transition:all var(--transition-fast);height:40px}.header-search input:focus{border-color:var(--color-primary);background:var(--color-white);box-shadow:0 0 0 3px var(--color-primary-50);outline:none}.header-search input::placeholder{color:var(--color-gray-400)}.header-search .search-icon{left:var(--space-3);color:var(--color-gray-400);width:18px;height:18px;position:absolute;top:50%;transform:translateY(-50%)}.header-right{align-items:center;gap:var(--space-3);display:flex}.header-icon-btn{border-radius:var(--radius-full);width:40px;height:40px;color:var(--color-gray-500);transition:all var(--transition-fast);cursor:pointer;justify-content:center;align-items:center;display:flex;position:relative}.header-icon-btn:hover{background:var(--color-gray-100);color:var(--color-gray-700)}.header-icon-btn .badge{border-radius:var(--radius-full);background:var(--color-error);width:18px;height:18px;color:var(--color-white);font-size:10px;font-weight:var(--font-weight-bold);border:2px solid var(--color-white);justify-content:center;align-items:center;display:flex;position:absolute;top:4px;right:4px}.header-user{align-items:center;gap:var(--space-3);border-radius:var(--radius-full);border:1px solid var(--border-color);background:var(--color-white);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-xs);padding:6px 14px;display:flex}.header-user:hover{background:var(--color-gray-50);border-color:var(--color-primary-200);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.header-user.active{background:var(--color-gray-50);border-color:var(--color-primary-light)}.header-user-avatar{border-radius:var(--radius-full);background:linear-gradient(135deg, var(--color-primary), var(--color-orange));width:32px;height:32px;color:var(--color-white);font-weight:var(--font-weight-bold);font-size:var(--font-size-base);border:2px solid var(--color-white);justify-content:center;align-items:center;display:flex;box-shadow:0 0 0 2px #0179a526}.header-user-info{flex-direction:column;display:flex}.header-user-name{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-gray-800);line-height:1.2}.header-user-role{font-size:var(--font-size-xs);color:var(--color-gray-500);line-height:1.2}.header-user .chevron-icon{color:var(--color-gray-400);transition:transform var(--transition-base), color var(--transition-base)}.header-user:hover .chevron-icon{color:var(--color-primary)}.header-user.active .chevron-icon{color:var(--color-primary);transform:rotate(180deg)}.page-header{margin-bottom:var(--space-6);justify-content:space-between;align-items:center;display:flex}.page-header-left{gap:var(--space-1);flex-direction:column;display:flex}.page-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900)}.page-subtitle{font-size:var(--font-size-base);color:var(--color-gray-500)}.page-breadcrumb{align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--color-gray-400);margin-bottom:var(--space-1);display:flex}.page-breadcrumb a{color:var(--color-gray-500);transition:color var(--transition-fast)}.page-breadcrumb a:hover{color:var(--color-primary)}.page-breadcrumb .separator{color:var(--color-gray-300)}.page-header-actions{align-items:center;gap:var(--space-3);display:flex}.card{background:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-card);transition:all var(--transition-base);flex-direction:column;height:100%;display:flex;overflow:hidden}.card:hover{box-shadow:var(--shadow-card-hover)}.card-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-color-light);justify-content:space-between;align-items:center;display:flex}.card-title{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-gray-800)}.card-body{padding:var(--space-5) var(--space-6)}.card-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-color-light);background:var(--color-gray-50)}.stat-card{background:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-card);padding:var(--space-5) var(--space-5);align-items:center;gap:var(--space-4);transition:all var(--transition-base);animation:.4s backwards fadeInUp;display:flex}.stat-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}.stat-card-icon{border-radius:var(--radius-lg);flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;display:flex}.stat-card-icon.blue{background:var(--color-primary-50);color:var(--color-primary)}.stat-card-icon.secondary{background:var(--color-secondary-50);color:var(--color-secondary)}.stat-card-icon.orange{background:var(--color-orange-50);color:var(--color-orange)}.stat-card-icon.green{background:var(--color-success-bg);color:var(--color-success)}.stat-card-icon.purple{color:#8b5cf6;background:#f3e8ff}.stat-card-content{flex-direction:column;min-width:0;display:flex}.stat-card-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900);line-height:1.2;animation:.5s backwards countUp}.stat-card-label{font-size:var(--font-size-sm);color:var(--color-gray-500);font-weight:var(--font-weight-medium);margin-top:var(--space-1)}.stat-card-trend{align-items:center;gap:var(--space-1);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);margin-top:var(--space-1);display:flex}.stat-card-trend.up{color:var(--color-success)}.stat-card-trend.down{color:var(--color-error)}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-5);border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:1px solid #0000;height:38px;text-decoration:none;display:inline-flex;position:relative;overflow:hidden}.btn:active{transform:scale(.98)}.btn-primary{background:var(--color-primary);color:var(--color-white);border-color:var(--color-primary)}.btn-primary:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark);box-shadow:0 2px 8px #0a4d8c4d}.btn-secondary{background:var(--color-secondary);color:var(--color-white);border-color:var(--color-secondary)}.btn-secondary:hover{background:var(--color-secondary-dark);box-shadow:0 2px 8px #00aeef4d}.btn-orange{background:var(--color-orange);color:var(--color-white);border-color:var(--color-orange)}.btn-orange:hover{background:var(--color-orange-dark);box-shadow:0 2px 8px #f7941d4d}.btn-success{background:var(--color-success);color:var(--color-white);border-color:var(--color-success)}.btn-success:hover{background:#059669;box-shadow:0 2px 8px #10b9814d}.btn-danger{background:var(--color-error);color:var(--color-white)}.btn-danger:hover{background:#dc2626;box-shadow:0 2px 8px #ef44444d}.btn-outline{color:var(--color-gray-700);border-color:var(--border-color);background:0 0}.btn-outline:hover{background:var(--color-gray-50);border-color:var(--color-gray-300)}.btn-ghost{color:var(--color-gray-600);background:0 0}.btn-ghost:hover{background:var(--color-gray-100);color:var(--color-gray-800)}.btn-sm{height:32px;padding:var(--space-1) var(--space-3);font-size:var(--font-size-sm);border-radius:var(--radius-sm)}.btn-lg{height:44px;padding:var(--space-3) var(--space-6);font-size:var(--font-size-md)}.btn-xl{height:50px;padding:var(--space-4) var(--space-8);font-size:var(--font-size-md);border-radius:var(--radius-lg)}.btn-icon{border-radius:var(--radius-md);width:38px;height:38px;padding:0}.btn-icon.sm{width:32px;height:32px}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn .spinner{border-radius:var(--radius-full);border:2px solid #0000;border-top-color:currentColor;width:16px;height:16px;animation:.6s linear infinite spin}.form-group{gap:var(--space-1);margin-bottom:var(--space-5);flex-direction:column;display:flex}.form-label{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-gray-700);align-items:center;gap:var(--space-1);display:flex}.form-label .required{color:var(--color-error)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--space-2) var(--space-3);border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--color-white);color:var(--color-gray-800);font-size:var(--font-size-base);transition:all var(--transition-fast);height:40px}.form-textarea{resize:vertical;height:auto;min-height:100px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-50);outline:none}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-gray-400)}.form-input.error,.form-select.error,.form-textarea.error{border-color:var(--color-error)}.form-input.error:focus{box-shadow:0 0 0 3px var(--color-error-bg)}.form-error{font-size:var(--font-size-sm);color:var(--color-error)}.form-hint{font-size:var(--font-size-sm);color:var(--color-gray-400)}.form-row{gap:var(--space-5);grid-template-columns:repeat(2,1fr);display:grid}.form-row-3{gap:var(--space-5);grid-template-columns:repeat(3,1fr);display:grid}.form-check{align-items:center;gap:var(--space-2);cursor:pointer;display:flex}.form-check input[type=checkbox],.form-check input[type=radio]{width:18px;height:18px;accent-color:var(--color-primary);cursor:pointer}.toggle-switch{border-radius:var(--radius-full);background:var(--color-gray-300);cursor:pointer;width:44px;height:24px;transition:background var(--transition-fast);position:relative}.toggle-switch.active{background:var(--color-success)}.toggle-switch:after{content:"";border-radius:var(--radius-full);background:var(--color-white);width:20px;height:20px;box-shadow:var(--shadow-sm);transition:transform var(--transition-fast);position:absolute;top:2px;left:2px}.toggle-switch.active:after{transform:translate(20px)}.file-upload{border:2px dashed var(--border-color);border-radius:var(--radius-lg);padding:var(--space-8) var(--space-6);text-align:center;cursor:pointer;transition:all var(--transition-fast);background:var(--color-gray-50)}.file-upload:hover,.file-upload.dragging{border-color:var(--color-primary);background:var(--color-primary-50)}.file-upload-icon{width:48px;height:48px;margin:0 auto var(--space-3);color:var(--color-gray-400)}.file-upload-text{font-size:var(--font-size-base);color:var(--color-gray-600);font-weight:var(--font-weight-medium)}.file-upload-hint{font-size:var(--font-size-sm);color:var(--color-gray-400);margin-top:var(--space-1)}.table-container{background:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-card);overflow:hidden}.table-toolbar{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-color-light);justify-content:space-between;align-items:center;gap:var(--space-4);display:flex}.table-toolbar-left,.table-toolbar-right{align-items:center;gap:var(--space-3);display:flex}.table-search{position:relative}.table-search input{width:280px;padding:var(--space-2) var(--space-3);padding-left:var(--space-8);border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--color-gray-50);font-size:var(--font-size-sm);height:36px}.table-search input:focus{border-color:var(--color-primary);background:var(--color-white);outline:none}.table-search .search-icon{left:var(--space-2);color:var(--color-gray-400);width:16px;height:16px;position:absolute;top:50%;transform:translateY(-50%)}table{border-collapse:collapse;width:100%}thead th{text-align:left;padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-gray-600);background:var(--color-gray-50);border-bottom:1px solid var(--border-color);white-space:nowrap;-webkit-user-select:none;user-select:none}thead th.sortable{cursor:pointer}thead th.sortable:hover{color:var(--color-gray-800)}tbody td{padding:var(--space-3) var(--space-4);font-size:var(--font-size-base);color:var(--color-gray-700);border-bottom:1px solid var(--border-color-light);vertical-align:middle}tbody tr{transition:background var(--transition-fast)}tbody tr:hover{background:var(--color-gray-50)}tbody tr:last-child td{border-bottom:none}.table-footer{padding:var(--space-3) var(--space-5);border-top:1px solid var(--border-color-light);font-size:var(--font-size-sm);color:var(--color-gray-500);justify-content:space-between;align-items:center;display:flex}.badge{align-items:center;gap:var(--space-1);padding:2px var(--space-2);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);white-space:nowrap;line-height:1.5;display:inline-flex}.badge-primary{background:var(--color-primary-50);color:var(--color-primary)}.badge-secondary{background:var(--color-secondary-50);color:var(--color-secondary-dark)}.badge-success{background:var(--color-success-bg);color:#059669}.badge-warning{background:var(--color-warning-bg);color:#d97706}.badge-danger{background:var(--color-error-bg);color:var(--color-error)}.badge-orange{background:var(--color-orange-50);color:var(--color-orange-dark)}.badge-info{background:var(--color-info-bg);color:#2563eb}.badge-gray{background:var(--color-gray-100);color:var(--color-gray-600)}.badge-dot{border-radius:var(--radius-full);background:currentColor;width:6px;height:6px}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-modal-overlay);background:#00000080;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:90%;max-width:600px;max-height:90vh;z-index:var(--z-modal);flex-direction:column;animation:.2s fadeInScale;display:flex}.modal-lg{max-width:800px}.modal-xl{max-width:1100px}.modal-full{max-width:95vw;max-height:95vh}.modal-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.modal-close{border-radius:var(--radius-md);width:32px;height:32px;color:var(--color-gray-400);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--color-gray-100);color:var(--color-gray-700)}.modal-body{padding:var(--space-6);flex:1;overflow-y:auto}.modal-footer{justify-content:flex-end;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-color);display:flex}.tabs{border-bottom:2px solid var(--border-color);align-items:center;gap:0;display:flex}.tab{padding:var(--space-3) var(--space-5);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-gray-500);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border-bottom:2px solid #0000;margin-bottom:-2px}.tab:hover{color:var(--color-gray-700)}.tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.pagination{align-items:center;gap:var(--space-1);display:flex}.pagination-btn{border-radius:var(--radius-md);width:32px;height:32px;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-600);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.pagination-btn:hover{background:var(--color-gray-100)}.pagination-btn.active{background:var(--color-primary);color:var(--color-white)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.empty-state{padding:var(--space-16) var(--space-8);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state-icon{width:80px;height:80px;margin-bottom:var(--space-5);color:var(--color-gray-300)}.empty-state-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-gray-700);margin-bottom:var(--space-2)}.empty-state-description{font-size:var(--font-size-base);color:var(--color-gray-400);max-width:400px;margin-bottom:var(--space-6)}.quick-action{align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);background:var(--color-white);border:1px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-xs);display:flex}.quick-action:hover{box-shadow:var(--shadow-md);border-color:var(--color-primary-100);transform:translateY(-2px)}.quick-action-icon{border-radius:var(--radius-md);background:var(--color-primary-50);width:40px;height:40px;color:var(--color-primary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.quick-action-label{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-gray-700)}.doc-item{align-items:center;gap:var(--space-4);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);transition:background var(--transition-fast);display:flex}.doc-item:hover{background:var(--color-gray-50)}.doc-item-image{border-radius:var(--radius-sm);object-fit:cover;background:var(--color-gray-100);flex-shrink:0;width:64px;height:48px}.doc-item-content{flex:1;min-width:0}.doc-item-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-gray-800);white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;overflow:hidden}.doc-item-meta{align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--color-gray-400);display:flex}.doc-item-actions{gap:var(--space-1);display:flex}.pdf-item{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);transition:background var(--transition-fast);display:flex}.pdf-item:hover{background:var(--color-gray-50)}.pdf-icon{border-radius:var(--radius-md);background:var(--color-error-bg);width:40px;height:40px;color:var(--color-error);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);flex-shrink:0;justify-content:center;align-items:center;display:flex}.card-body .doc-item,.card-body .pdf-item{border-bottom:1px solid var(--border-color-light);border-radius:0;padding:14px 16px}.card-body .doc-item:hover,.card-body .pdf-item:hover{background:var(--color-gray-50)}.card-body .doc-item:last-child,.card-body .pdf-item:last-child{border-bottom:none}.notification-dropdown{background:var(--color-white);border-radius:var(--radius-xl);width:380px;max-height:480px;z-index:var(--z-dropdown);border:1px solid #00000014;animation:.2s fadeInScale;position:absolute;top:calc(100% + 10px);right:0;overflow:hidden;box-shadow:0 10px 30px #00000014,0 1px 3px #00000005}.notification-item{gap:var(--space-3);border-bottom:1px solid var(--border-color-light);cursor:pointer;transition:all var(--transition-base);padding:14px 18px;display:flex}.notification-item:hover{background:var(--color-primary-50)}.notification-item.unread{background:#f0f9ff}.notification-item.unread:hover{background:#e0f2fe}.dashboard-stats{gap:var(--space-5);margin-bottom:var(--space-6);grid-template-columns:repeat(4,1fr);display:grid}.dashboard-grid{gap:var(--space-6);grid-template-columns:1fr 1fr 320px;display:grid}.dashboard-grid-2{gap:var(--space-6);grid-template-columns:1fr 1fr;display:grid}.quick-actions-grid{gap:var(--space-4);margin-bottom:var(--space-6);grid-template-columns:repeat(4,1fr);display:grid}.auth-page{background:var(--color-bg);min-height:100vh;display:flex}.auth-hero{padding:var(--space-12);background:#011d29;flex:1.2;align-items:flex-end;display:flex;position:relative;overflow:hidden}.auth-hero-image{object-fit:cover;opacity:.65;filter:saturate(1.1)contrast(1.05);width:100%;height:100%;position:absolute;inset:0}.auth-hero-overlay{z-index:1;background:linear-gradient(135deg,#0179a566 0%,#005676cc 50%,#ed3231bf 100%);position:absolute;inset:0}.auth-hero-glow-1{z-index:2;pointer-events:none;background:radial-gradient(circle,#fe910040 0%,#0000 70%);width:50%;height:50%;position:absolute;top:-10%;left:-10%}.auth-hero-glow-2{z-index:2;pointer-events:none;background:radial-gradient(circle,#ed323133 0%,#0000 70%);width:50%;height:50%;position:absolute;bottom:-10%;right:-10%}.auth-hero-content{z-index:3;color:var(--color-white);max-width:640px;position:relative}.auth-hero-badge{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);letter-spacing:.08em;text-transform:uppercase;margin-bottom:var(--space-4);box-shadow:var(--shadow-sm);background:#ffffff26;border:1px solid #ffffff40;align-items:center;padding:6px 14px;display:inline-flex}.auth-hero-content h1{font-size:var(--font-size-4xl);font-weight:var(--font-weight-extrabold);color:var(--color-white);margin-bottom:var(--space-4);text-shadow:0 2px 10px #0003;line-height:1.15}.auth-hero-content p{font-size:var(--font-size-lg);color:#fffffff2;line-height:var(--line-height-relaxed);margin-bottom:var(--space-6)}.auth-hero-features{gap:var(--space-3);margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid #ffffff26;flex-direction:column;display:flex}.auth-hero-feature-item{align-items:center;gap:var(--space-3);font-size:var(--font-size-base);color:#ffffffe6;display:flex}.feature-dot{background:var(--color-orange);width:8px;height:8px;box-shadow:0 0 10px var(--color-orange-light);border-radius:50%}.auth-form-side{padding:var(--space-12);background:var(--color-white);z-index:10;flex-direction:column;flex:1;justify-content:center;display:flex;box-shadow:-10px 0 30px #00000008}.auth-form-wrapper{width:100%;max-width:440px;margin:0 auto}.auth-logo{margin-bottom:var(--space-8);justify-content:flex-start;display:flex}.auth-logo img.original-logo{object-fit:contain;width:auto;height:52px}.auth-tabs{background:var(--color-gray-100);border-radius:var(--radius-lg);margin-bottom:var(--space-8);padding:4px;display:flex}.auth-tab-btn{border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-gray-500);transition:all var(--transition-base);cursor:pointer;text-align:center;background:0 0;border:none;flex:1;padding:10px 16px}.auth-tab-btn.active{background:var(--color-white);color:var(--color-primary);box-shadow:var(--shadow-sm)}.auth-form-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-extrabold);color:var(--color-gray-900);margin-bottom:var(--space-1)}.auth-form-subtitle{font-size:var(--font-size-base);color:var(--color-gray-500);margin-bottom:var(--space-6)}.auth-error-alert{background:var(--color-error-bg);color:var(--color-error);border-radius:var(--radius-md);font-size:var(--font-size-base);margin-bottom:var(--space-5);font-weight:var(--font-weight-semibold);border-left:4px solid var(--color-error);padding:12px 16px}.auth-form .form-group{margin-bottom:var(--space-4)}.input-with-icon{align-items:center;display:flex;position:relative}.input-icon{color:var(--color-gray-400);transition:color var(--transition-fast);pointer-events:none;position:absolute;left:14px}.input-with-icon .form-input{height:48px;font-size:var(--font-size-base);width:100%;padding-left:42px;padding-right:14px}.input-with-icon .form-input:focus~.input-icon{color:var(--color-primary)}.password-toggle-btn{color:var(--color-gray-400);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;display:flex;position:absolute;right:14px}.password-toggle-btn:hover{color:var(--color-gray-700)}.form-row{gap:var(--space-4);display:flex}.form-row>.form-group,.form-row .col{flex:1;min-width:0}.select-styled{appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;background-size:16px;height:48px;padding-right:40px!important}.auth-form-footer{margin-bottom:var(--space-5);justify-content:space-between;align-items:center;display:flex}.auth-form-footer .form-check{align-items:center;gap:var(--space-2);font-size:var(--font-size-base);color:var(--color-gray-600);cursor:pointer;display:flex}.auth-form-footer .form-check input{cursor:pointer}.auth-link{font-size:var(--font-size-base);color:var(--color-primary);font-weight:var(--font-weight-semibold)}.auth-link:hover{color:var(--color-primary-light);text-decoration:underline}.auth-copyright{margin-top:var(--space-8);padding-top:var(--space-6);border-top:1px solid var(--color-gray-100);text-align:center;font-size:var(--font-size-xs);color:var(--color-gray-400);line-height:var(--line-height-relaxed)}.wizard{flex-direction:column;display:flex}.wizard-steps{padding:var(--space-6) var(--space-8);background:var(--color-white);border-bottom:1px solid var(--border-color);margin-bottom:var(--space-6);justify-content:center;align-items:center;gap:0;display:flex}.wizard-step{align-items:center;gap:var(--space-2);display:flex}.wizard-step-number{border-radius:var(--radius-full);width:32px;height:32px;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);border:2px solid var(--color-gray-300);color:var(--color-gray-400);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.wizard-step.active .wizard-step-number{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-white)}.wizard-step.completed .wizard-step-number{background:var(--color-success);border-color:var(--color-success);color:var(--color-white)}.wizard-step-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-400)}.wizard-step.active .wizard-step-label{color:var(--color-primary)}.wizard-step.completed .wizard-step-label{color:var(--color-success)}.wizard-connector{background:var(--color-gray-200);width:60px;height:2px;margin:0 var(--space-2)}.wizard-connector.completed{background:var(--color-success)}.itinerary-day{background:var(--color-white);border:1px solid var(--border-color);border-radius:var(--radius-lg);margin-bottom:var(--space-4);transition:all var(--transition-base);animation:.3s backwards fadeInUp}.itinerary-day:hover{box-shadow:var(--shadow-md)}.itinerary-day-header{align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);background:var(--color-primary-50);border-bottom:1px solid var(--border-color-light);border-radius:var(--radius-lg) var(--radius-lg) 0 0;cursor:grab;display:flex}.itinerary-day-header:active{cursor:grabbing}.itinerary-day-number{border-radius:var(--radius-full);background:var(--color-primary);width:36px;height:36px;color:var(--color-white);font-weight:var(--font-weight-bold);font-size:var(--font-size-base);flex-shrink:0;justify-content:center;align-items:center;display:flex}.itinerary-day-title{font-weight:var(--font-weight-semibold);color:var(--color-gray-800);flex:1}.itinerary-day-body{padding:var(--space-5)}.gallery-grid{gap:var(--space-3);grid-template-columns:repeat(auto-fill,minmax(150px,1fr));display:grid}.gallery-item{aspect-ratio:4/3;border-radius:var(--radius-md);cursor:pointer;group:true;position:relative;overflow:hidden}.gallery-item img{object-fit:cover;width:100%;height:100%;transition:transform var(--transition-slow)}.gallery-item:hover img{transform:scale(1.05)}.gallery-item-overlay{opacity:0;transition:opacity var(--transition-fast);background:#0006;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.gallery-item:hover .gallery-item-overlay{opacity:1}.status-dot{border-radius:var(--radius-full);flex-shrink:0;width:8px;height:8px}.status-dot.active{background:var(--color-success)}.status-dot.inactive{background:var(--color-gray-400)}.status-dot.draft{background:var(--color-warning)}.storage-chart{align-items:center;gap:var(--space-4);flex-direction:column;display:flex}.storage-chart-visual{width:140px;height:140px;position:relative}.storage-chart-center{flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.storage-chart-percent{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-gray-800)}.storage-chart-label{font-size:var(--font-size-xs);color:var(--color-gray-500)}.storage-legend{gap:var(--space-2);flex-direction:column;width:100%;display:flex}.storage-legend-item{align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);display:flex}.storage-legend-dot{border-radius:var(--radius-full);flex-shrink:0;width:8px;height:8px}.quick-links{gap:var(--space-1);flex-direction:column;display:flex}.quick-link-item{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);color:inherit;text-decoration:none;display:flex}.quick-link-item:hover{background:var(--color-gray-50)}.quick-link-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.quick-link-content{flex:1;min-width:0}.quick-link-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-gray-800)}.quick-link-desc{font-size:var(--font-size-xs);color:var(--color-gray-400)}.branding-card{background:linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);border-radius:var(--radius-lg);padding:var(--space-6);color:var(--color-white);text-align:center}.branding-card img{max-height:60px;margin:0 auto var(--space-4);filter:brightness(0)invert()}.branding-card h3{color:var(--color-white);font-size:var(--font-size-lg);margin-bottom:var(--space-2)}.branding-card p{font-size:var(--font-size-sm);opacity:.85;line-height:var(--line-height-relaxed)}.app-footer{padding:var(--space-4) var(--space-8);font-size:var(--font-size-sm);color:var(--color-gray-400);border-top:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-top:auto;display:flex}.detail-grid{gap:var(--space-6);grid-template-columns:2fr 1fr;display:grid}.detail-section{margin-bottom:var(--space-6)}.detail-section-title{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-gray-800);margin-bottom:var(--space-4);padding-bottom:var(--space-2);border-bottom:1px solid var(--border-color)}.detail-field{gap:var(--space-1);margin-bottom:var(--space-4);flex-direction:column;display:flex}.detail-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.03em}.detail-value{font-size:var(--font-size-base);color:var(--color-gray-800)}.settings-section{background:var(--color-white);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-6);margin-bottom:var(--space-6)}.settings-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-gray-800);margin-bottom:var(--space-5);padding-bottom:var(--space-3);border-bottom:1px solid var(--border-color-light)}.audit-item{align-items:flex-start;gap:var(--space-3);padding:var(--space-3) 0;border-bottom:1px solid var(--border-color-light);display:flex}.audit-icon{border-radius:var(--radius-full);width:32px;height:32px;font-size:var(--font-size-sm);flex-shrink:0;justify-content:center;align-items:center;display:flex}.permission-matrix{border-collapse:collapse;width:100%}.permission-matrix th{padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);text-align:center;background:var(--color-gray-50);border:1px solid var(--border-color)}.permission-matrix th:first-child{text-align:left}.permission-matrix td{padding:var(--space-3) var(--space-4);text-align:center;border:1px solid var(--border-color-light)}.permission-matrix td:first-child{text-align:left;font-weight:var(--font-weight-medium)}.preview-pane{background:var(--color-white);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden}.preview-pane-header{padding:var(--space-3) var(--space-5);background:var(--color-gray-50);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;display:flex}.preview-pane-body{padding:var(--space-6);min-height:400px}.skeleton{background:linear-gradient(90deg, var(--color-gray-100) 25%, var(--color-gray-200) 50%, var(--color-gray-100) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s infinite shimmer}.skeleton-text{width:100%;height:16px;margin-bottom:var(--space-2)}.skeleton-text.sm{width:60%}.skeleton-circle{border-radius:var(--radius-full);width:40px;height:40px}.skeleton-card{width:100%;height:120px}.toast-custom{font-family:var(--font-family)!important;font-size:var(--font-size-base)!important;border-radius:var(--radius-lg)!important;box-shadow:var(--shadow-lg)!important}.text-center{text-align:center}.text-right{text-align:right}.text-primary{color:var(--color-primary)}.text-secondary{color:var(--color-secondary)}.text-muted{color:var(--color-gray-500)}.text-success{color:var(--color-success)}.text-error{color:var(--color-error)}.text-sm{font-size:var(--font-size-sm)}.text-lg{font-size:var(--font-size-lg)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.flex-1{flex:1}.flex-wrap{flex-wrap:wrap}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mr-2{margin-right:var(--space-2)}.ml-auto{margin-left:auto}.p-4{padding:var(--space-4)}.p-6{padding:var(--space-6)}.px-4{padding-left:var(--space-4);padding-right:var(--space-4)}.py-2{padding-top:var(--space-2);padding-bottom:var(--space-2)}.w-full{width:100%}.h-full{height:100%}.rounded{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-full{border-radius:var(--radius-full)}.shadow{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.overflow-hidden{overflow:hidden}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.whitespace-nowrap{white-space:nowrap}.cursor-pointer{cursor:pointer}.select-none{-webkit-user-select:none;user-select:none}.relative{position:relative}.border{border:1px solid var(--border-color)}.border-b{border-bottom:1px solid var(--border-color)}.animate-fade-in{animation:.3s fadeIn}.animate-fade-up{animation:.4s fadeInUp}.animate-slide-left{animation:.3s slideInLeft}.animate-bounce-in{animation:.5s bounceIn}.stagger-1{animation-delay:50ms}.stagger-2{animation-delay:.1s}.stagger-3{animation-delay:.15s}.stagger-4{animation-delay:.2s}.stagger-5{animation-delay:.25s}.stagger-6{animation-delay:.3s}.stagger-7{animation-delay:.35s}.stagger-8{animation-delay:.4s}.stagger-9{animation-delay:.45s}.stagger-10{animation-delay:.5s}.view-all-link{padding:var(--space-3);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-primary);border-top:1px solid var(--border-color-light);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;margin-top:auto;display:flex}.view-all-link:hover{background:var(--color-gray-50);color:var(--color-primary-dark)}.master-grid{gap:var(--space-5);grid-template-columns:repeat(auto-fill,minmax(320px,1fr));display:grid}.image-container{border-radius:var(--radius-md);position:relative;overflow:hidden}.image-container img{object-fit:cover;width:100%;height:100%;transition:transform var(--transition-slow)}.image-container:hover img{transform:scale(1.05)}.filter-bar{align-items:center;gap:var(--space-3);padding:var(--space-3) 0;flex-wrap:wrap;display:flex}.filter-chip{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);border:1px solid var(--border-color);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-600);cursor:pointer;transition:all var(--transition-fast);background:var(--color-white);display:inline-flex}.filter-chip:hover{border-color:var(--color-primary);color:var(--color-primary)}.filter-chip.active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-white)}.tag-list{gap:var(--space-2);flex-wrap:wrap;display:flex}.tag{align-items:center;gap:var(--space-1);padding:2px var(--space-2);border-radius:var(--radius-sm);background:var(--color-primary-50);color:var(--color-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);display:inline-flex}.tag-remove{border-radius:var(--radius-full);cursor:pointer;opacity:.6;width:16px;height:16px;transition:opacity var(--transition-fast);justify-content:center;align-items:center;display:flex}.tag-remove:hover{opacity:1;background:#0000001a}.checkbox-grid{gap:var(--space-3);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));display:grid}.schedule-row{gap:var(--space-3);padding:var(--space-2) 0;border-bottom:1px solid var(--border-color-light);grid-template-columns:120px 1fr 150px 120px 1fr 48px;align-items:center;display:grid}.user-dropdown{background:var(--color-white);border-radius:var(--radius-xl);width:240px;z-index:var(--z-dropdown);border:1px solid #00000014;padding:8px;animation:.2s fadeInScale;position:absolute;top:calc(100% + 10px);right:0;overflow:hidden;box-shadow:0 10px 30px #00000014,0 1px 3px #00000005}.user-dropdown-item{align-items:center;gap:var(--space-3);font-size:var(--font-size-base);color:var(--color-gray-700);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-base);padding:10px 14px;display:flex}.user-dropdown-item svg{transition:transform var(--transition-base), color var(--transition-base)}.user-dropdown-item:hover{background:var(--color-primary-50);color:var(--color-primary);padding-left:18px}.user-dropdown-item:hover svg{color:var(--color-primary);transform:scale(1.1)}.user-dropdown-divider{background:var(--border-color-light);height:1px;margin:6px 8px}.form-select{appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-position:right 12px center;background-repeat:no-repeat;background-size:16px;padding-right:40px}.star-rating{color:var(--color-orange);gap:2px;display:flex}.drag-handle{cursor:grab;color:var(--color-gray-400);padding:var(--space-1);align-items:center;display:flex}.drag-handle:active{cursor:grabbing}:root{--sa-accent:#6366f1;--sa-accent-dark:#4f46e5;--sa-accent-light:#818cf8;--sa-bg:#f8fafc;--sa-sidebar-bg:#090d1a;--user-accent:#0d9488;--user-accent-light:#14b8a6}.sa-login-page{background:linear-gradient(135deg,#f1f5f9 0%,#e2e8f0 100%);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.sa-login-bg{z-index:0;position:absolute;inset:0}.sa-login-grid{background-image:linear-gradient(#6366f10a 1px,#0000 1px),linear-gradient(90deg,#6366f10a 1px,#0000 1px);background-size:60px 60px;animation:8s ease-in-out infinite gridPulse;position:absolute;inset:0}@keyframes gridPulse{0%,to{opacity:.4}50%{opacity:.8}}.sa-login-glow-1{background:radial-gradient(circle,#6366f11f 0%,#0000 70%);border-radius:50%;width:500px;height:500px;animation:6s ease-in-out infinite glowFloat;position:absolute;top:-20%;left:-10%}.sa-login-glow-2{background:radial-gradient(circle,#8b5cf614 0%,#0000 70%);border-radius:50%;width:600px;height:600px;animation:8s ease-in-out infinite reverse glowFloat;position:absolute;bottom:-20%;right:-10%}@keyframes glowFloat{0%,to{transform:translate(0)scale(1)}50%{transform:translate(20px,-20px)scale(1.1)}}.sa-login-card{z-index:1;width:100%;max-width:440px;padding:48px 40px;position:relative;-webkit-backdrop-filter:blur(24px)saturate(180%)!important;backdrop-filter:blur(24px)saturate(180%)!important;background:#fffc!important;border:1px solid #6366f126!important;border-radius:24px!important;box-shadow:0 30px 60px #6366f114,inset 0 1px #fff9!important}.sa-login-badge{color:var(--sa-accent);letter-spacing:.15em;text-transform:uppercase;text-align:center;background:#6366f10f;border:1px solid #6366f126;border-radius:30px;justify-content:center;align-items:center;gap:10px;width:max-content;margin:0 auto 24px;padding:6px 18px;font-size:11px;font-weight:700;display:flex}.sa-login-badge svg{filter:drop-shadow(0 0 4px #6366f14d)}.sa-login-title{text-align:center;color:#0f172a;background:linear-gradient(135deg,#0f172a 30%,#4f46e5 100%);-webkit-text-fill-color:transparent;letter-spacing:-.02em;-webkit-background-clip:text;background-clip:text;margin-bottom:8px;font-size:28px;font-weight:800}.sa-login-subtitle{text-align:center;color:#64748b;margin-bottom:32px;font-size:13.5px;line-height:1.6}.sa-login-card .form-label{color:#334155;letter-spacing:.03em;font-size:12px;font-weight:600}.sa-login-card .form-input,.sa-login-card .sa-input{color:#0f172a!important;background:#fff!important;border:1px solid #cbd5e1!important;border-radius:12px!important;height:44px!important;font-size:13.5px!important;transition:all .25s!important}.sa-login-card .form-input:focus,.sa-login-card .sa-input:focus{background:#fff!important;border-color:#6366f199!important;box-shadow:0 0 0 3px #6366f126!important}.sa-login-card .form-input::placeholder,.sa-login-card .input-icon,.sa-login-card .password-toggle-btn{color:#94a3b8!important}.sa-login-card .password-toggle-btn:hover{color:#0f172a!important}.sa-login-card .auth-error-alert{color:#991b1b!important;background:#fef2f2!important;border:1px solid #fecaca!important;border-radius:12px!important;margin-bottom:24px!important;padding:12px 16px!important;font-size:13px!important}.sa-login-footer{text-align:center;color:#94a3b8;margin-top:32px;font-size:11.5px;line-height:1.5}.btn-sa{background:linear-gradient(135deg, var(--sa-accent), var(--sa-accent-light))!important;color:#fff!important;cursor:pointer!important;border:1px solid #ffffff1a!important;border-radius:12px!important;justify-content:center!important;align-items:center!important;gap:8px!important;padding:12px 24px!important;font-weight:600!important;transition:all .25s!important;display:inline-flex!important;box-shadow:0 4px 12px #6366f133!important}.btn-sa:hover{transform:translateY(-1px)!important;box-shadow:0 6px 18px #6366f14d!important}.btn-sa:active{transform:translateY(1px)!important}.sa-sidebar .sidebar-footer{background:var(--sa-sidebar-bg)!important}.sa-logo-badge{background:#6366f11a;border:1px solid #6366f133;border-radius:12px;justify-content:center;align-items:center;gap:10px;width:100%;padding:10px 20px;display:flex}.sa-logo-badge svg{color:var(--sa-accent-light)}.sa-logo-text{color:#fff;letter-spacing:.04em;font-size:15px;font-weight:700}.sa-sidebar .sidebar-item.active{background:var(--sa-accent)!important}.sa-header{background:#fff}.sa-badge-inline{letter-spacing:.1em;color:var(--sa-accent);vertical-align:middle;background:#6366f11a;border-radius:20px;align-items:center;margin-left:8px;padding:3px 10px;font-size:10px;font-weight:700;display:inline-flex}.sa-avatar{background:linear-gradient(135deg, var(--sa-accent), #8b5cf6)!important;box-shadow:0 0 0 2px #6366f133!important}.user-login-page{background:linear-gradient(135deg,#f0fdfa,#e0f2fe,#ede9fe);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.user-login-bg{z-index:0;position:absolute;inset:0}.user-login-pattern{background-image:radial-gradient(circle at 1px 1px,#0d948814 1px,#0000 0);background-size:40px 40px;position:absolute;inset:0}.user-login-glow-1{background:radial-gradient(circle,#0d948826 0%,#0000 70%);border-radius:50%;width:500px;height:500px;animation:7s ease-in-out infinite glowFloat;position:absolute;top:-15%;right:-10%}.user-login-glow-2{background:radial-gradient(circle,#3b82f61a 0%,#0000 70%);border-radius:50%;width:500px;height:500px;animation:9s ease-in-out infinite reverse glowFloat;position:absolute;bottom:-15%;left:-10%}.user-login-card{z-index:1;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffffeb;border:1px solid #0d94881f;border-radius:20px;width:100%;max-width:420px;padding:44px 36px;position:relative;box-shadow:0 20px 60px #00000014,0 0 30px #0d94880d}.user-login-icon{background:linear-gradient(135deg, var(--user-accent), var(--user-accent-light));color:#fff;border-radius:16px;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 20px;display:flex;box-shadow:0 8px 24px #0d948840}.user-login-title{text-align:center;color:var(--color-gray-900);margin-bottom:6px;font-size:24px;font-weight:800}.user-login-subtitle{text-align:center;color:var(--color-gray-500);margin-bottom:28px;font-size:14px}.user-login-footer{text-align:center;color:var(--color-gray-400);margin-top:28px;font-size:12px}.btn-user-primary{background:linear-gradient(135deg, var(--user-accent), var(--user-accent-light));color:#fff;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);border:none;justify-content:center;align-items:center;gap:8px;width:100%;padding:12px 24px;font-weight:600;display:inline-flex;box-shadow:0 4px 12px #0d94884d}.btn-user-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #0d948866}.user-sidebar .sidebar-item.active{background:var(--user-accent)!important}.user-header .user-role-badge{color:var(--user-accent);letter-spacing:.05em;text-transform:uppercase;background:#0d94881a;border-radius:12px;align-items:center;padding:2px 8px;font-size:10px;font-weight:700;display:inline-flex}.user-avatar-style{background:linear-gradient(135deg, var(--user-accent), var(--user-accent-light))!important;box-shadow:0 0 0 2px #0d948833!important}.sidebar-view-badge{color:var(--color-warning);vertical-align:middle;background:#f59e0b1f;border-radius:8px;align-items:center;gap:3px;margin-left:6px;padding:1px 6px;font-size:9px;font-weight:600;display:inline-flex}.user-dashboard-welcome{margin-bottom:var(--space-6)}.user-dashboard-welcome h2{color:var(--color-gray-900);margin-bottom:4px;font-size:22px;font-weight:700}.user-dashboard-welcome p{color:var(--color-gray-500);font-size:14px}.user-module-grid{gap:var(--space-5);margin-bottom:var(--space-8);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.user-module-card{align-items:center;gap:var(--space-4);padding:var(--space-5) var(--space-6);background:var(--color-white);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);transition:all var(--transition-base);display:flex}.user-module-card:hover:not(.locked){box-shadow:var(--shadow-card-hover);border-color:var(--user-accent);transform:translateY(-2px)}.user-module-card.locked{opacity:.55}.user-module-icon{border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;display:flex}.user-module-info{flex:1}.user-module-info h3{color:var(--color-gray-800);margin-bottom:4px;font-size:15px;font-weight:600}.user-access-badge{border-radius:12px;align-items:center;gap:4px;padding:2px 10px;font-size:12px;font-weight:600;display:inline-flex}.user-access-badge.full{color:var(--color-success);background:var(--color-success-bg)}.user-access-badge.view{color:var(--color-warning);background:var(--color-warning-bg)}.user-access-badge.locked{color:var(--color-gray-400);background:var(--color-gray-100)}.user-info-card{background:var(--color-white);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-card)}.user-info-card h4{margin-bottom:var(--space-4);color:var(--color-gray-800);font-size:16px;font-weight:600}.user-info-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));display:grid}.user-info-item{flex-direction:column;gap:2px;display:flex}.user-info-label{color:var(--color-gray-400);text-transform:uppercase;letter-spacing:.06em;font-size:12px;font-weight:500}.user-info-value{color:var(--color-gray-800);font-size:15px;font-weight:600}.perm-matrix-section{margin-top:var(--space-5);padding-top:var(--space-5);border-top:1px solid var(--border-color)}.perm-matrix-title{color:var(--color-gray-800);margin-bottom:var(--space-4);align-items:center;gap:8px;font-size:15px;font-weight:600;display:flex}.perm-matrix{background:var(--color-gray-50);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden}.perm-matrix-header{background:var(--color-gray-100);border-bottom:1px solid var(--border-color);color:var(--color-gray-600);text-transform:uppercase;letter-spacing:.05em;grid-template-columns:1fr repeat(3,100px);gap:0;padding:10px 16px;font-size:12px;font-weight:600;display:grid}.perm-matrix-row{border-bottom:1px solid var(--border-color-light);transition:background var(--transition-fast);grid-template-columns:1fr repeat(3,100px);align-items:center;gap:0;padding:12px 16px;display:grid}.perm-matrix-row:last-child{border-bottom:none}.perm-matrix-row:hover{background:var(--color-white)}.perm-matrix-module{color:var(--color-gray-700);font-size:14px;font-weight:500}.perm-matrix-option{justify-content:center;align-items:center;display:flex}.perm-radio{cursor:pointer;justify-content:center;align-items:center;display:flex}.perm-radio input{display:none}.perm-radio-dot{border:2px solid var(--color-gray-300);width:20px;height:20px;transition:all var(--transition-fast);border-radius:50%;position:relative}.perm-radio input:checked+.perm-radio-dot{border-width:6px}.perm-radio:hover .perm-radio-dot{border-color:var(--color-gray-400);transform:scale(1.1)}.sa-admin-create-section{margin-top:var(--space-5);padding:var(--space-4);border-radius:var(--radius-md);background:#6366f10a;border:1px dashed #6366f133}.sa-stat-card{border-left:3px solid #0000}.sa-stat-card:first-child{border-left-color:var(--sa-accent)}.sa-stat-card:nth-child(2){border-left-color:#10b981}.sa-stat-card:nth-child(3){border-left-color:#f59e0b}.sa-stat-card:nth-child(4){border-left-color:#8b5cf6}.sa-quick-action:hover{border-color:var(--sa-accent)}.badge-warning{background:var(--color-warning-bg);color:#b45309;font-size:12px;font-weight:500}.sidebar-section-title{justify-content:space-between!important;align-items:center!important;gap:8px!important;display:flex!important}.sidebar-view-badge{color:#d97706!important;text-transform:uppercase!important;letter-spacing:.05em!important;background:#f59e0b26!important;border:1px solid #f59e0b4d!important;border-radius:4px!important;flex-shrink:0!important;align-items:center!important;gap:4px!important;padding:1px 6px!important;font-size:9px!important;font-weight:700!important;line-height:1!important;display:inline-flex!important}.user-sidebar{background:#06262a!important;border-right:1px solid #14b8a626!important}.user-sidebar .sidebar-logo{background:#06262a!important;border-bottom:1px solid #14b8a626!important}.user-sidebar .sidebar-footer{background:#06262a!important;border-top:1px solid #14b8a626!important}.user-sidebar .sidebar-item{transition:all .2s!important}.user-sidebar .sidebar-item:hover{color:#fff!important;background:#14b8a614!important}.user-sidebar .sidebar-item.active{background:var(--user-accent)!important;color:#fff!important;box-shadow:0 4px 12px #0d948859!important}.user-sidebar .sidebar-sub-item{color:#ffffffa6!important;background:0 0!important;border-left:2px solid #0000!important;transition:all .2s!important}.user-sidebar .sidebar-sub-item:hover{color:var(--user-accent-light)!important;background:0 0!important;border-left-color:#14b8a64d!important}.user-sidebar .sidebar-sub-item.active{color:var(--user-accent-light)!important;border-left-color:var(--user-accent-light)!important;background:0 0!important;font-weight:600!important}.user-sidebar .sidebar-sub-item:before{display:none!important}.sa-layout{color:#334155!important;background:#f8fafc!important}.sa-layout .app-main,.sa-layout .app-content{background:#f8fafc!important}.sa-layout .app-footer{color:#64748b!important;background:#fff!important;border-top:1px solid #e2e8f0!important}.sa-layout .app-footer span{color:#64748b!important}.sa-layout .sa-header{color:#0f172a!important;background:#fff!important;border-bottom:1px solid #e2e8f0!important}.sa-layout .sa-header h2{color:#0f172a!important}.sa-layout .sa-header p{color:#64748b!important}.sa-layout .header-user{color:#334155!important;background:#f1f5f9!important;border:1px solid #e2e8f0!important}.sa-layout .header-user:hover,.sa-layout .header-user.active{color:#4f46e5!important;background:#6366f10d!important;border-color:#6366f140!important}.sa-layout .header-user-name{color:#334155!important}.sa-layout .header-user-role,.sa-layout .chevron-icon{color:#64748b!important}.sa-layout .user-dropdown{color:#334155!important;background:#fff!important;border:1px solid #6366f126!important;box-shadow:0 10px 30px #6366f114!important}.sa-layout .user-dropdown-item{color:#475569!important}.sa-layout .user-dropdown-item:hover{color:#4f46e5!important;background:#6366f10d!important}.sa-layout .user-dropdown-divider{border-bottom:1px solid #6366f114!important}.sa-sidebar{background:var(--sa-sidebar-bg)!important;border-right:1px solid #ffffff14!important}.sa-sidebar .sidebar-logo{background:#fff!important;border-bottom:1px solid #e2e8f0!important;border-right:1px solid #e2e8f0!important}.sa-sidebar .sa-logo-badge{background:#fff!important;border:1px solid #e2e8f0!important;box-shadow:0 4px 12px #6366f114!important}.sa-sidebar .sa-logo-text{color:#0f172a!important}.sa-sidebar .sa-logo-badge svg{color:var(--sa-accent)!important}.sa-sidebar .sidebar-footer{background:var(--sa-sidebar-bg)!important;border-top:1px solid #ffffff14!important}.sa-sidebar .sidebar-item{color:#ffffffb3!important;transition:all .2s!important}.sa-sidebar .sidebar-item:hover{color:#fff!important;background:#ffffff0f!important}.sa-sidebar .sidebar-item.active{background:var(--sa-accent)!important;color:#fff!important;box-shadow:0 4px 12px #6366f159!important}.sa-sidebar .sidebar-section-title{color:#fff6!important}.sa-layout .page-title{color:#0f172a!important;text-shadow:none!important}.sa-layout .page-subtitle{color:#64748b!important}.sa-layout .sa-stat-card{background:#fff!important;border:1px solid #e2e8f0!important;transition:all .3s cubic-bezier(.4,0,.2,1)!important;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -2px #0000000d!important}.sa-layout .sa-stat-card:hover{border-color:#6366f140!important;transform:translateY(-2px)!important;box-shadow:0 10px 20px #6366f114!important}.sa-layout .sa-stat-card .stat-card-value{color:#0f172a!important;font-weight:800!important}.sa-layout .sa-stat-card .stat-card-label{color:#64748b!important;font-weight:500!important}.sa-layout .sa-quick-action{color:#334155!important;background:#fff!important;border:1px solid #e2e8f0!important;transition:all .25s!important;box-shadow:0 4px 6px -1px #0000000d!important}.sa-layout .sa-quick-action:hover{border-color:var(--sa-accent)!important;background:#6366f10a!important;transform:translateY(-2px)!important;box-shadow:0 8px 20px #6366f114!important}.sa-layout .sa-quick-action .quick-action-label{color:#334155!important;font-weight:600!important}.sa-layout .card{background:#fff!important;border:1px solid #e2e8f0!important;box-shadow:0 4px 6px -1px #0000000d!important}.sa-layout .card-header{border-bottom:1px solid #e2e8f0!important}.sa-layout .card-title{color:#0f172a!important;font-weight:700!important}.sa-layout .doc-item{border-bottom:1px solid #f1f5f9!important;transition:all .2s!important}.sa-layout .doc-item:hover{background:#6366f105!important;padding-left:6px!important}.sa-layout .doc-item-title{color:#1e293b!important;font-weight:600!important}.sa-layout .doc-item-meta span{color:#64748b!important}.sa-layout .table-container{background:#fff!important;border:1px solid #e2e8f0!important;box-shadow:0 4px 6px -1px #0000000d!important}.sa-layout .table-toolbar{border-bottom:1px solid #e2e8f0!important}.sa-layout table th{color:#475569!important;letter-spacing:.05em!important;background:#f8fafc!important;border-bottom:2px solid #e2e8f0!important;font-size:11px!important;font-weight:700!important}.sa-layout table td{color:#334155!important;border-bottom:1px solid #f1f5f9!important;font-size:13px!important}.sa-layout table tbody tr:hover td{background:#6366f105!important}.sa-layout table tbody tr{background:0 0!important}.sa-layout .table-search{background:#fff!important;border:1px solid #cbd5e1!important}.sa-layout .table-search input{color:#0f172a!important}.sa-layout .table-search .search-icon{color:#94a3b8!important}.sa-layout .form-input,.sa-layout .form-select{color:#0f172a!important;background:#fff!important;border:1px solid #cbd5e1!important;transition:all .2s!important}.sa-layout .form-input:focus,.sa-layout .form-select:focus{border-color:var(--sa-accent)!important;box-shadow:0 0 0 3px #6366f126!important}.sa-layout .form-label{color:#475569!important;font-weight:500!important}.sa-layout .modal-overlay{-webkit-backdrop-filter:blur(8px)!important;backdrop-filter:blur(8px)!important;background:#0f172a80!important}.sa-layout .modal{background:#fff!important;border:1px solid #e2e8f0!important;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a!important}.sa-layout .modal-header{border-bottom:1px solid #e2e8f0!important}.sa-layout .modal-title{color:#0f172a!important;font-weight:700!important}.sa-layout .modal-close{color:#64748b!important}.sa-layout .modal-close:hover{color:#0f172a!important}.sa-layout .modal-footer{border-top:1px solid #e2e8f0!important}.sa-layout .btn-outline{color:#475569!important;background:0 0!important;border-color:#cbd5e1!important}.sa-layout .btn-outline:hover{color:#1e293b!important;background:#f8fafc!important;border-color:#cbd5e1!important}.sa-layout .sa-admin-create-section{border-radius:8px;margin-top:16px;padding:16px;background:#6366f105!important;border:1px solid #6366f11a!important}.sa-layout .form-check input[type=checkbox]{background-color:#fff!important;border-color:#cbd5e1!important}.sa-layout .form-check input[type=checkbox]:checked{background-color:var(--sa-accent)!important;border-color:var(--sa-accent)!important}
