.auth-layout{align-items:center;background:linear-gradient(135deg,var(--royal-blue) 0,var(--sea-green) 100%);display:flex;justify-content:center;min-height:100vh;padding:20px}.auth-layout-container{align-items:center;display:flex;flex-direction:column;max-width:420px;width:100%}.auth-layout-brand{margin-bottom:32px;text-align:center}.auth-layout-logo{align-items:center;background-color:var(--golden-yellow);border-radius:50%;box-shadow:0 4px 12px #0003;color:var(--charcoal-gray);display:flex;font-size:36px;font-weight:700;height:72px;justify-content:center;margin:0 auto 16px;width:72px}.auth-layout-title{color:#fff;font-size:28px;font-weight:700;margin:0 0 8px}.auth-layout-subtitle{color:#fffc;font-size:14px;margin:0}.auth-layout-content{background-color:var(--bg-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:32px;width:100%}.auth-layout-footer{margin-top:24px;text-align:center}.auth-layout-footer p{color:#fff9;font-size:12px;margin:0}@media (max-width:480px){.auth-layout{padding:16px}.auth-layout-content{padding:24px}.auth-layout-title{font-size:24px}.auth-layout-logo{font-size:30px;height:60px;width:60px}}.spinner{align-items:center;display:inline-flex;justify-content:center}.spinner-circle{animation:spin .8s linear infinite;border-radius:50%;border-right-color:#0000;border-style:solid;border-top-color:#0000}.spinner-sm .spinner-circle{border-width:2px;height:16px;width:16px}.spinner-md .spinner-circle{border-width:3px;height:24px;width:24px}.spinner-lg .spinner-circle{border-width:4px;height:40px;width:40px}.spinner-primary .spinner-circle{border-bottom-color:var(--royal-blue);border-left-color:var(--royal-blue)}.spinner-secondary .spinner-circle{border-bottom-color:var(--sea-green);border-left-color:var(--sea-green)}.spinner-white .spinner-circle{border-bottom-color:#fff;border-left-color:#fff}.btn{align-items:center;border:2px solid #0000;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-weight:500;gap:8px;justify-content:center;text-decoration:none;transition:all var(--transition-fast);white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.5}.btn:focus{box-shadow:0 0 0 3px #0a4e7633;outline:none}.btn-sm{font-size:14px;height:32px;padding:0 12px}.btn-md{font-size:14px;height:40px;padding:0 20px}.btn-lg{font-size:16px;height:48px;padding:0 28px}.btn-primary{background-color:var(--royal-blue);border-color:var(--royal-blue);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--royal-blue-dark);border-color:var(--royal-blue-dark)}.btn-secondary{background-color:var(--sea-green);border-color:var(--sea-green);color:#fff}.btn-secondary:hover:not(:disabled){background-color:var(--sea-green-dark);border-color:var(--sea-green-dark)}.btn-success{background-color:var(--emerald-green);border-color:var(--emerald-green);color:#fff}.btn-success:hover:not(:disabled){background-color:var(--emerald-green-dark);border-color:var(--emerald-green-dark)}.btn-danger{background-color:var(--color-error);border-color:var(--color-error);color:#fff}.btn-danger:hover:not(:disabled){background-color:#dc2626;border-color:#dc2626}.btn-outline{background-color:initial;border-color:var(--border-medium);color:var(--royal-blue)}.btn-outline:hover:not(:disabled){background-color:var(--bg-tertiary);border-color:var(--royal-blue)}.btn-ghost{background-color:initial;border-color:#0000;color:var(--text-primary)}.btn-ghost:hover:not(:disabled){background-color:var(--bg-tertiary)}.btn-full{width:100%}.btn-loading{position:relative}.btn-loading .btn-text{opacity:0}.btn-loading .spinner{position:absolute}.btn-icon{flex-shrink:0}.input-container{display:flex;flex-direction:column;gap:6px;width:100%}.input-label{color:var(--text-primary);font-size:14px;font-weight:500}.input-required{color:var(--color-error);margin-left:4px}.input-wrapper{align-items:center;display:flex;position:relative}.input{background-color:var(--bg-primary);border:1px solid var(--border-medium);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;height:42px;padding:0 14px;transition:all var(--transition-fast);width:100%}.input:hover:not(:disabled){border-color:var(--border-dark)}.input:focus{border-color:var(--royal-blue);box-shadow:0 0 0 3px #0a4e761a;outline:none}.input::placeholder{color:var(--text-tertiary)}.input:disabled{background-color:var(--bg-tertiary);cursor:not-allowed}.input-icon{color:var(--text-tertiary);pointer-events:none;position:absolute}.input-icon-left{left:12px}.input-with-icon{padding-left:40px}.input-prefix,.input-suffix{color:var(--text-secondary);font-size:14px;position:absolute}.input-prefix{left:14px}.input-with-prefix{padding-left:36px}.input-suffix{right:14px}.input-with-suffix{padding-right:40px}.input-password-toggle{background:none;border:none;border-radius:var(--radius-sm);color:var(--text-tertiary);cursor:pointer;padding:4px;position:absolute;right:10px}.input-password-toggle:hover{background-color:var(--bg-tertiary);color:var(--text-secondary)}.input-helper{align-items:center;color:var(--text-secondary);display:flex;font-size:12px;gap:6px}.input-helper-error{color:var(--color-error)}.input-error .input{border-color:var(--color-error)}.input-error .input:focus{box-shadow:0 0 0 3px #ef44441a}.input-disabled{opacity:.6}.select-container{display:flex;flex-direction:column;gap:6px;width:100%}.select-label{color:var(--text-primary);font-size:14px;font-weight:500}.select-required{color:var(--color-error);margin-left:4px}.select-wrapper{align-items:center;display:flex;position:relative}.select{-webkit-appearance:none;appearance:none;background-color:var(--bg-primary);border:1px solid var(--border-medium);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;font-size:14px;height:42px;padding:0 40px 0 14px;transition:all var(--transition-fast);width:100%}.select:hover:not(:disabled){border-color:var(--border-dark)}.select:focus{border-color:var(--royal-blue);box-shadow:0 0 0 3px #0a4e761a;outline:none}.select:disabled{background-color:var(--bg-tertiary);cursor:not-allowed}.select-icon{color:var(--text-tertiary);pointer-events:none;position:absolute;right:12px}.select-helper{align-items:center;color:var(--text-secondary);display:flex;font-size:12px;gap:6px}.select-helper-error{color:var(--color-error)}.select-error .select{border-color:var(--color-error)}.select-error .select:focus{box-shadow:0 0 0 3px #ef44441a}.select-disabled{opacity:.6}.card{overflow:hidden}.card-no-padding .card-body{padding:0}.card-header{align-items:center;background-color:var(--bg-primary);display:flex;justify-content:space-between;padding:16px 24px}.card-header-content{flex:1 1}.card-title{color:var(--text-primary);font-size:16px;font-weight:600;margin:0}.card-subtitle{color:var(--text-secondary);font-size:14px;margin:4px 0 0}.card-header-action{margin-left:16px}.card-body{padding:24px}.card-footer{align-items:center;background-color:var(--bg-secondary);border-top:1px solid var(--border-light);display:flex;gap:12px;justify-content:flex-end;padding:16px 24px}@media (max-width:640px){.card-body,.card-footer,.card-header{padding-left:16px;padding-right:16px}}.modal-overlay{align-items:center;animation:fadeIn .2s ease-out;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:500}.modal{animation:slideUp .3s ease-out;background-color:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;max-height:calc(100vh - 40px)}.modal-sm{max-width:400px;width:100%}.modal-md{max-width:560px;width:100%}.modal-lg{max-width:720px;width:100%}.modal-xl{max-width:900px;width:100%}.modal-full{max-width:none;width:calc(100vw - 40px)}.modal-header{align-items:center;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;padding:16px 24px}.modal-title{color:var(--text-primary);font-size:18px;font-weight:600;margin:0}.modal-close{align-items:center;background:none;border:none;border-radius:var(--radius-md);color:var(--text-tertiary);cursor:pointer;display:flex;height:32px;justify-content:center;padding:0;transition:all var(--transition-fast);width:32px}.modal-close:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.modal-body{flex:1 1;overflow-y:auto;padding:24px}.modal-footer{align-items:center;background-color:var(--bg-secondary);border-radius:0 0 var(--radius-lg) var(--radius-lg);border-top:1px solid var(--border-light);display:flex;gap:12px;justify-content:flex-end;padding:16px 24px}@media (max-width:640px){.modal-overlay{padding:10px}.modal-body,.modal-footer,.modal-header{padding-left:16px;padding-right:16px}}.alert{align-items:flex-start;border:1px solid;border-radius:var(--radius-md);display:flex;gap:12px;padding:14px 16px}.alert-icon{flex-shrink:0;margin-top:1px}.alert-content{flex:1 1}.alert-title{font-weight:600;margin-bottom:4px}.alert-message{font-size:14px;line-height:1.5}.alert-close{background:none;border:none;border-radius:var(--radius-sm);color:inherit;cursor:pointer;flex-shrink:0;opacity:.7;padding:4px}.alert-close:hover{background-color:#0000001a;opacity:1}.alert-success{background-color:#2bae661a;border-color:#2bae664d;color:var(--emerald-green-dark)}.alert-error{background-color:#ef44441a;border-color:#ef44444d;color:#dc2626}.alert-warning{background-color:#f59e0b1a;border-color:#f59e0b4d;color:#b45309}.alert-info{background-color:#3b82f61a;border-color:#3b82f64d;color:#2563eb}.badge{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-weight:500;gap:6px;white-space:nowrap}.badge-sm{font-size:11px;padding:2px 8px}.badge-md{font-size:12px;padding:4px 10px}.badge-lg{font-size:14px;padding:6px 12px}.badge-default{background-color:var(--bg-tertiary);color:var(--text-secondary)}.badge-primary{background-color:#0a4e761a;color:var(--royal-blue)}.badge-secondary{background-color:#00b5c91a;color:var(--sea-green-dark)}.badge-success{background-color:#2bae661a;color:var(--emerald-green-dark)}.badge-warning{background-color:#f59e0b1a;color:#b45309}.badge-error{background-color:#ef44441a;color:#dc2626}.badge-info{background-color:#3b82f61a;color:#2563eb}.badge-dot{background-color:currentColor;border-radius:50%;height:6px;width:6px}.confirm-dialog{padding:8px;text-align:center}.confirm-dialog-icon{align-items:center;border-radius:50%;display:inline-flex;height:48px;justify-content:center;margin-bottom:16px;width:48px}.confirm-dialog-icon-danger{background-color:#ef44441a;color:var(--color-error)}.confirm-dialog-icon-warning{background-color:#f59e0b1a;color:var(--color-warning)}.confirm-dialog-icon-primary{background-color:#0a4e761a;color:var(--royal-blue)}.confirm-dialog-title{color:var(--text-primary);font-size:18px;font-weight:600;margin:0 0 8px}.confirm-dialog-message{color:var(--text-secondary);font-size:14px;line-height:1.5;margin:0 0 24px}.confirm-dialog-actions{display:flex;gap:12px;justify-content:center}.confirm-dialog-actions .btn{min-width:100px}.quick-add-overlay{align-items:center;animation:fadeIn .2s ease;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.quick-add-modal{animation:slideUp .3s ease;background:var(--bg-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-height:90vh;max-width:560px;overflow:hidden;width:90%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.quick-add-header{align-items:center;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;padding:20px 24px}.quick-add-header h2{font-size:20px;font-weight:600;margin:0}.quick-add-close{align-items:center;background:var(--bg-secondary);border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:flex;height:36px;justify-content:center;transition:all var(--transition-fast);width:36px}.quick-add-close:hover{background:var(--bg-hover);color:var(--text-primary)}.quick-add-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr);padding:20px 24px}.quick-add-item{align-items:center;background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);cursor:pointer;display:flex;gap:14px;padding:16px;text-align:left;transition:all var(--transition-fast)}.quick-add-item:hover{background:var(--bg-secondary);border-color:var(--royal-blue);box-shadow:var(--shadow-md);transform:translateY(-2px)}.quick-add-icon{align-items:center;border-radius:var(--radius-lg);display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.quick-add-info{display:flex;flex-direction:column;gap:2px;min-width:0}.quick-add-label{color:var(--text-primary);font-size:14px;font-weight:600}.quick-add-desc{color:var(--text-tertiary);font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.quick-add-footer{border-top:1px solid var(--border-light);padding:12px 24px;text-align:center}.quick-add-footer p{color:var(--text-tertiary);font-size:12px;margin:0}.quick-add-footer kbd{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-sm);display:inline-block;font-family:inherit;font-size:11px;margin:0 2px;padding:2px 6px}@media (max-width:600px){.quick-add-modal{margin:16px;width:95%}.quick-add-grid{gap:8px;grid-template-columns:1fr;padding:16px}.quick-add-item{padding:14px}.quick-add-icon{height:40px;width:40px}}.header{background-color:var(--bg-primary);border-bottom:1px solid var(--border-light);height:60px;justify-content:space-between;padding:0 24px}.header,.header-left{align-items:center;display:flex}.header-left{gap:16px}.menu-toggle{align-items:center;background:none;border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:none;height:40px;justify-content:center;transition:all var(--transition-fast);width:40px}.menu-toggle:hover{background-color:var(--bg-hover);color:var(--text-primary)}.logo{align-items:center;display:flex;gap:10px;text-decoration:none}.logo-icon{font-size:28px}.logo-text{color:var(--royal-blue);font-size:18px;font-weight:700}.header-center{align-items:center;display:flex}.account-selector{position:relative}.account-selector-btn{align-items:center;background-color:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-full);cursor:pointer;display:flex;gap:8px;padding:8px 16px;transition:all var(--transition-fast)}.account-selector-btn:hover{border-color:var(--royal-blue)}.account-icon{align-items:center;background-color:var(--royal-blue);border-radius:var(--radius-full);color:#fff;display:flex;font-size:12px;height:24px;justify-content:center;width:24px}.account-name{color:var(--text-primary);font-size:14px;font-weight:500;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.account-dropdown-icon{color:var(--text-tertiary)}.account-dropdown{background-color:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);left:50%;min-width:200px;overflow:hidden;position:absolute;top:calc(100% + 8px);transform:translateX(-50%);z-index:100}.account-option{align-items:center;background:none;border:none;cursor:pointer;display:flex;gap:10px;padding:12px 16px;text-align:left;transition:background-color var(--transition-fast);width:100%}.account-option:hover{background-color:var(--bg-hover)}.account-option.active{background-color:#0a4e761a}.header-right{gap:8px}.header-btn,.header-right{align-items:center;display:flex}.header-btn{background:none;border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;height:40px;justify-content:center;position:relative;transition:all var(--transition-fast);width:40px}.header-btn:hover{background-color:var(--bg-hover);color:var(--text-primary)}.header-btn.primary{background-color:var(--royal-blue);color:#fff}.header-btn.primary:hover{background-color:var(--royal-blue-dark)}.notification-badge{align-items:center;background-color:var(--color-error);border-radius:var(--radius-full);color:#fff;display:flex;font-size:10px;font-weight:600;height:16px;justify-content:center;position:absolute;right:6px;top:6px;width:16px}.user-menu{position:relative}.user-btn{align-items:center;background:none;border:none;border-radius:var(--radius-full);cursor:pointer;display:flex;gap:8px;padding:4px;transition:all var(--transition-fast)}.user-btn:hover{background-color:var(--bg-hover)}.user-avatar{align-items:center;background-color:var(--sea-green);border-radius:var(--radius-full);color:#fff;display:flex;font-size:14px;font-weight:600;height:36px;justify-content:center;width:36px}.user-dropdown{background-color:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:180px;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);z-index:100}.user-dropdown-item{align-items:center;background:none;border:none;color:var(--text-primary);cursor:pointer;display:flex;font-size:14px;gap:10px;padding:12px 16px;text-align:left;transition:background-color var(--transition-fast);width:100%}.user-dropdown-item:hover{background-color:var(--bg-hover)}.user-dropdown-item.danger{color:var(--color-error)}@media (max-width:768px){.header{padding:0 16px}.menu-toggle{display:flex}.account-name,.logo-text{display:none}}.sidebar{display:flex;flex:1 1;flex-direction:column;overflow-y:auto;padding:8px 0}.sidebar.collapsed .nav-link{justify-content:center;padding:12px}.sidebar.collapsed .nav-label,.sidebar.collapsed .submenu,.sidebar.collapsed .submenu-toggle svg:last-child{display:none}.nav-list{flex:1 1;list-style:none;margin:0;padding:0}.nav-item{margin:2px 8px}.nav-item.highlight{margin-bottom:8px;margin-top:8px}.nav-item.highlight .nav-link{background:linear-gradient(135deg,#10b9811a,#0596691a);border:1px solid #10b98133}.nav-item.highlight .nav-link:hover{background:linear-gradient(135deg,#10b98126,#05966926);border-color:#10b9814d}.nav-item.highlight .nav-link.active{background:linear-gradient(135deg,#10b98133,#05966933);border-color:#10b98166;color:#059669}.nav-item.highlight .nav-icon{color:#10b981}.nav-link{align-items:center;background:none;border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:12px;padding:10px 12px;text-align:left;text-decoration:none;transition:all var(--transition-fast);width:100%}.nav-link:hover{background-color:var(--bg-hover);color:var(--text-primary)}.nav-link.active{background-color:#0a4e761a;color:var(--royal-blue)}.nav-icon{flex-shrink:0;height:20px;width:20px}.nav-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.submenu-toggle svg:last-child{margin-left:auto}.submenu{list-style:none;margin:0;padding:4px 0 4px 20px}.submenu-item{margin:2px 0}.submenu-link{align-items:center;border-radius:var(--radius-md);color:var(--text-secondary);display:flex;font-size:13px;font-weight:400;gap:10px;padding:8px 12px;text-decoration:none;transition:all var(--transition-fast)}.submenu-link:hover{background-color:var(--bg-hover);color:var(--text-primary)}.submenu-link.active{background-color:#0a4e761a;color:var(--royal-blue)}.submenu-icon{flex-shrink:0;height:16px;width:16px}.sidebar-footer{border-top:1px solid var(--border-light);flex-shrink:0;padding:12px 16px;text-align:center}.version{color:var(--text-tertiary);font-size:11px}.main-layout{display:flex;flex-direction:column;height:100vh;overflow:hidden}.layout-header{flex-shrink:0;z-index:20}.layout-body{display:flex;flex:1 1;overflow:hidden}.layout-sidebar{background-color:var(--bg-primary);border-right:1px solid var(--border-light);display:flex;flex-direction:column;flex-shrink:0;height:100%;position:relative;transition:width var(--transition-normal);width:240px}.layout-sidebar.collapsed{width:64px}.collapse-toggle{align-items:center;background:#0000;border:none;border-left:1px solid var(--border-light);color:var(--text-tertiary);cursor:pointer;display:flex;font-size:12px;height:60px;justify-content:center;position:absolute;right:0;top:50%;transform:translateY(-50%);transition:all var(--transition-fast);width:16px;z-index:10}.collapse-toggle:hover{background-color:var(--bg-hover);color:var(--text-primary)}.layout-main{background-color:var(--bg-secondary);flex:1 1;overflow-y:auto;padding:24px}@media (max-width:768px){.layout-sidebar{height:calc(100% - 60px);left:0;position:fixed;top:60px;transform:translateX(-100%);transition:transform var(--transition-normal);z-index:100}.layout-sidebar.open{transform:translateX(0)}.collapse-toggle{display:none}.layout-main{padding:16px}}:root{--royal-blue:#0a4e76;--royal-blue-light:#0d6291;--royal-blue-dark:#073a59;--sea-green:#00b5c9;--sea-green-light:#00d4eb;--sea-green-dark:#008a9a;--golden-yellow:#ffb800;--golden-yellow-light:#ffc933;--golden-yellow-dark:#cc9300;--emerald-green:#2bae66;--emerald-green-light:#3fbf7a;--emerald-green-dark:#228b52;--pearl-white:#fff8f4;--charcoal-gray:#2c2b2c;--color-primary:var(--royal-blue);--color-secondary:var(--sea-green);--color-accent:var(--golden-yellow);--color-success:var(--emerald-green);--color-warning:#f59e0b;--color-error:#ef4444;--color-info:#3b82f6;--text-primary:var(--charcoal-gray);--text-secondary:#6b7280;--text-tertiary:#9ca3af;--text-inverse:#fff;--text-link:var(--royal-blue);--bg-primary:#fff;--bg-secondary:var(--pearl-white);--bg-tertiary:#f3f4f6;--bg-dark:var(--charcoal-gray);--border-light:#e5e7eb;--border-medium:#d1d5db;--border-dark:#9ca3af;--status-active:var(--emerald-green);--status-inactive:#9ca3af;--status-pending:var(--golden-yellow);--status-overdue:var(--color-error);--status-paid:var(--emerald-green);--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-full:9999px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-6:24px;--space-8:32px;--text-xs:12px;--text-sm:14px;--text-base:16px;--text-lg:18px;--text-xl:20px;--text-2xl:24px;--text-3xl:30px;--font-normal:400;--font-medium:500;--font-semibold:600;--font-bold:700;--transition-fast:150ms ease;--transition-normal:300ms ease;--header-height:64px;--sidebar-width:260px;--sidebar-collapsed-width:72px}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{background-color:var(--bg-secondary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:var(--text-base);font-weight:var(--font-normal);line-height:1.5;min-height:100vh}body,h1,h2,h3,h4,h5,h6{color:var(--text-primary)}h1,h2,h3,h4,h5,h6{font-weight:var(--font-semibold);line-height:1.25}h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}h4{font-size:var(--text-lg)}a{color:var(--text-link);text-decoration:none}a:hover{text-decoration:underline}ol,ul{list-style:none}img{display:block;max-width:100%}button,input,select,textarea{color:inherit;font:inherit}button{background:none;border:none;cursor:pointer}button:disabled{cursor:not-allowed}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--border-dark)}#root{min-height:100vh}.app{display:flex;flex-direction:column}.page{margin:0 auto;max-width:1400px;padding:var(--space-6)}.page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--space-6)}.page-title{font-size:var(--text-2xl);font-weight:var(--font-semibold)}.card{background-color:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.card-header{border-bottom:1px solid var(--border-light);padding:var(--space-4) var(--space-6)}.card-body{padding:var(--space-6)}.text-center{text-align:center}.text-right{text-align:right}.text-success{color:var(--color-success)}.text-error{color:var(--color-error)}.text-warning{color:var(--color-warning)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--space-2)}.gap-4{gap:var(--space-4)}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.w-full{width:100%}.rounded{border-radius:var(--radius-md)}.shadow{box-shadow:var(--shadow-md)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.animate-spin{animation:spin 1s linear infinite}.animate-fadeIn{animation:fadeIn .3s ease-out}.app,.app-loading{background:var(--bg-primary);min-height:100vh}.app-loading{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center}.app-loading-spinner{animation:spin .8s linear infinite;border:4px solid var(--border-light);border-radius:50%;border-top-color:var(--royal-blue);height:48px;width:48px}.app-loading p{color:var(--text-secondary);font-size:14px}.page-loader{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:400px;padding:40px}.page-loader-spinner{animation:spin .8s linear infinite;border:3px solid var(--border-light);border-radius:50%;border-top-color:var(--sea-green);height:40px;width:40px}.page-loader p{color:var(--text-secondary);font-size:14px;margin:0}.placeholder-page{padding:40px;text-align:center}.placeholder-page h1{color:var(--text-primary);margin-bottom:8px}.placeholder-page p{color:var(--text-secondary)}@keyframes spin{to{transform:rotate(1turn)}}.app-loading-spinner,.page-loader-spinner{will-change:transform}.layout-main{contain:layout style}.layout-main,.layout-sidebar{-webkit-overflow-scrolling:touch}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}@media (max-width:768px){.app-loading-spinner,.page-loader-spinner{height:36px;width:36px}}.login-page{width:100%}.login-title{color:var(--text-primary);font-size:24px;font-weight:700;margin:0 0 8px;text-align:center}.login-subtitle{color:var(--text-secondary);font-size:14px;margin:0 0 24px;text-align:center}.login-alert{margin-bottom:20px}.login-form{display:flex;flex-direction:column;gap:20px}.login-options{display:flex;justify-content:flex-end;margin-top:-8px}.login-forgot-link{color:var(--royal-blue);font-size:14px;text-decoration:none}.login-forgot-link:hover{text-decoration:underline}.login-footer{align-items:center;border-top:1px solid var(--border-light);color:var(--text-tertiary);display:flex;font-size:13px;gap:8px;justify-content:center;margin-top:24px;padding-top:20px}
/*# sourceMappingURL=main.8aeb8c52.css.map*/