@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";.login-card{border:1px solid #0000000f;border-radius:20px;grid-template-columns:1.15fr 1fr;width:100%;max-width:980px;min-height:600px;display:grid;overflow:hidden;box-shadow:0 24px 60px #18181b2e,0 8px 20px #18181b14}.login-root{background:radial-gradient(800px 500px at 85% 0,#c8102e12 0%,#0000 55%),radial-gradient(700px 500px at 0 100%,#c8102e0d 0%,#0000 55%),#f4f4f5;justify-content:center;align-items:center;height:100vh;min-height:100vh;padding:0;display:flex;overflow:hidden}.login-card{width:100vw;max-width:100%;height:100vh;box-shadow:none;border:none;border-radius:0;grid-template-columns:1.15fr 1fr;min-height:100vh;display:grid;overflow:hidden}.login-brand{background:#c8102e;flex-direction:column;justify-content:space-between;padding:44px;display:flex;position:relative;overflow:hidden}.login-brand-pattern{opacity:.13;pointer-events:none;width:100%;height:100%;position:absolute;inset:0}.login-brand-glow-top{pointer-events:none;background:radial-gradient(circle,#ffffff21 0%,#0000 70%);border-radius:50%;width:340px;height:340px;position:absolute;top:-110px;right:-110px}.login-brand-glow-bottom{pointer-events:none;background:radial-gradient(circle,#00000024 0%,#0000 70%);border-radius:50%;width:240px;height:240px;position:absolute;bottom:-90px;left:-70px}.login-brand-ring-1{pointer-events:none;border:1.5px solid #ffffff24;border-radius:50%;width:165px;height:165px;position:absolute;top:38%;right:-55px}.login-brand-ring-2{pointer-events:none;border:1.5px solid #ffffff1a;border-radius:50%;width:105px;height:105px;position:absolute;top:43%;right:-28px}.login-brand-logo{z-index:1;align-items:center;gap:13px;display:flex;position:relative}.login-brand-logo-icon{background:#fff;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:24px;display:flex;box-shadow:0 8px 24px #00000038}.login-brand-logo-text{flex-direction:column;display:flex}.login-brand-logo-text span:first-child{color:#fff;letter-spacing:-.3px;font-size:17px;font-weight:800;line-height:1.15}.login-brand-logo-text span:last-child{color:#ffffffb8;letter-spacing:.1em;text-transform:uppercase;font-size:10px;font-weight:600}.login-brand-content{z-index:1;position:relative}.login-brand-tag{color:#fff;letter-spacing:.09em;text-transform:uppercase;background:#ffffff29;border:1px solid #ffffff47;border-radius:99px;align-items:center;gap:7px;margin-bottom:20px;padding:5px 12px;font-size:10px;font-weight:700;display:inline-flex}.login-brand-tag-dot{opacity:.9;background:#fff;border-radius:50%;width:5px;height:5px;animation:2s infinite pulse-dot}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.45;transform:scale(.78)}}.login-brand-content h1{color:#fff;letter-spacing:-.5px;margin-bottom:12px;font-size:34px;font-weight:900;line-height:1.2}.login-brand-content h1 em{color:#ffffff80;font-style:normal}.login-brand-content p{color:#ffffffd6;max-width:270px;font-size:13px;line-height:1.65}.login-features{z-index:1;flex-direction:column;gap:10px;display:flex;position:relative}.login-feature-item{align-items:center;gap:11px;display:flex}.login-feature-icon{background:#ffffff24;border:1px solid #fff3;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:31px;height:31px;font-size:14px;display:flex}.login-feature-item span{color:#ffffffeb;font-size:12.5px;font-weight:400}.login-brand-footer{z-index:1;color:#ffffff8c;margin-top:12px;font-size:10.5px;position:relative}.login-form-panel{background:#fff;flex-direction:column;justify-content:center;align-items:center;padding:52px 50px;display:flex;position:relative;overflow:hidden}.login-form-pattern{opacity:.045;pointer-events:none;width:100%;height:100%;position:absolute;inset:0}.login-form-panel:before{content:"";background:linear-gradient(90deg,#c8102e,#82091e);height:4px;position:absolute;top:0;left:0;right:0}.login-form-inner{z-index:1;width:100%;max-width:360px;animation:.3s forwards fadeIn;position:relative}.login-form-header{margin-bottom:28px}.login-form-header h2{color:#18181b;letter-spacing:-.4px;font-size:26px;font-weight:800;font-family:var(--font-sans);margin-bottom:5px}.login-form-header p{color:#a1a1aa;font-size:13px;line-height:1.5}.login-error-alert{color:#c8102e;background:#fef2f3;border:1px solid #f9b3b8;border-radius:9px;align-items:flex-start;gap:10px;margin-bottom:14px;padding:11px 14px;font-size:13px;font-weight:500;animation:.2s fadeIn;display:flex}.login-error-alert .alert-icon{flex-shrink:0;margin-top:1px;font-size:15px}.login-creds-card{background:#fff;border:1px solid #e4e4e7;border-radius:14px;margin-bottom:16px;padding:22px;box-shadow:0 2px 14px #18181b12}.login-creds-label{color:#a1a1aa;letter-spacing:.08em;text-transform:uppercase;font-size:10.5px;font-weight:700;font-family:var(--font-sans);margin-bottom:16px}.login-field{flex-direction:column;gap:6px;margin-bottom:14px;display:flex}.login-field:last-child{margin-bottom:0}.login-field label{color:#52525b;letter-spacing:.01em;font-size:12px;font-weight:600;font-family:var(--font-sans)}.login-input-wrap{align-items:center;display:flex;position:relative}.login-input-icon{color:#a1a1aa;pointer-events:none;font-size:15px;transition:color .15s;position:absolute;left:13px}.login-input{width:100%;height:44px;font-size:14px;font-family:var(--font-sans);color:#18181b;background:#fafafa;border:1.5px solid #dcdce0;border-radius:9px;outline:none;padding:0 40px;transition:all .15s}.login-input::placeholder{color:#a1a1aa}.login-input:hover{background:#fff;border-color:#a1a1aa}.login-input:focus{background:#fff;border-color:#c8102e;box-shadow:0 0 0 3px #c8102e1a}.login-input-wrap:focus-within .login-input-icon{color:#c8102e}.login-input.has-error{border-color:#dc2626;box-shadow:0 0 0 3px #dc262614}.login-pw-toggle{cursor:pointer;color:#a1a1aa;background:0 0;border:none;align-items:center;padding:4px;font-size:15px;transition:color .15s;display:flex;position:absolute;right:12px}.login-pw-toggle:hover{color:#52525b}.login-field-error{color:#dc2626;align-items:center;gap:4px;margin-top:1px;font-size:11.5px;display:flex}.login-btn{color:#fff;width:100%;height:46px;font-size:15px;font-weight:700;font-family:var(--font-sans);cursor:pointer;letter-spacing:.02em;background:#c8102e;border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;margin-bottom:18px;transition:all .2s;display:flex;box-shadow:0 8px 22px #c8102e61}.login-btn:hover:not(:disabled){background:#a60d26;transform:translateY(-1px);box-shadow:0 10px 28px #c8102e70}.login-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 5px 14px #c8102e47}.login-btn:disabled{opacity:.65;cursor:not-allowed;transform:none}.login-spinner{border:2.5px solid #ffffff59;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-divider{color:#a1a1aa;font-size:11.5px;font-family:var(--font-sans);align-items:center;gap:10px;margin-bottom:14px;display:flex}.login-divider:before,.login-divider:after{content:"";background:#ececee;flex:1;height:1px}.login-signup-link{text-align:center;color:#71717a;font-size:13px;font-family:var(--font-sans)}.login-signup-link a{color:#c8102e;margin-left:4px;font-weight:700;text-decoration:none;transition:color .15s}.login-signup-link a:hover{color:#a60d26;text-decoration:underline}@media (width<=900px){.login-card{grid-template-columns:1fr;min-height:auto}.login-brand{display:none}.login-form-panel{padding:44px 28px}}@media (width<=480px){.login-root{background:#fff;padding:0}.login-card{box-shadow:none;border-radius:0;min-height:100vh}.login-form-panel{padding:40px 22px}.login-form-inner{max-width:100%}}.signup-root{background:radial-gradient(ellipse 900px 500px at 90% -5%, #e61a2714 0%, transparent 60%), radial-gradient(ellipse 600px 400px at -5% 100%, #e61a270d 0%, transparent 60%), var(--bg-app);justify-content:center;align-items:center;min-height:100vh;padding:40px 20px;display:flex;position:relative;overflow:hidden}.signup-root:before{content:"B2B";color:#e61a2709;pointer-events:none;-webkit-user-select:none;user-select:none;letter-spacing:-10px;font-size:280px;font-weight:900;line-height:1;position:absolute;bottom:-40px;right:-20px}.signup-card{background:var(--bg-card);border-radius:var(--radius-xl);width:100%;max-width:580px;box-shadow:var(--shadow-xl);border:1px solid var(--border-light);z-index:1;animation:.3s forwards fadeIn;position:relative;overflow:hidden}.signup-header{background:linear-gradient(135deg, var(--red-500) 0%, var(--red-700) 100%);padding:28px 36px 24px;position:relative;overflow:hidden}.signup-header:after{content:"";pointer-events:none;background:radial-gradient(circle,#ffffff24 0%,#0000 70%);border-radius:50%;width:200px;height:200px;position:absolute;top:-60px;right:-60px}.signup-header-top{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.signup-logo{align-items:center;gap:10px;display:flex}.signup-logo-icon{background:var(--white);border-radius:10px;justify-content:center;align-items:center;width:38px;height:38px;font-size:19px;display:flex;box-shadow:0 4px 12px #00000026}.signup-logo-text{color:var(--white);letter-spacing:-.2px;font-size:15px;font-weight:700}.signup-logo-sub{color:#ffffffbf;letter-spacing:.05em;text-transform:uppercase;font-size:10px;font-weight:500}.signup-steps{align-items:center;gap:6px;display:flex}.signup-step-dot{width:8px;height:8px;transition:var(--transition-base);background:#ffffff59;border-radius:50%}.signup-step-dot.active{background:var(--white);border-radius:4px;width:24px}.signup-step-dot.done{background:#fff9}.signup-header h2{color:var(--white);letter-spacing:-.3px;margin-bottom:4px;font-size:22px;font-weight:800}.signup-header p{color:#ffffffd9;font-size:13px}.signup-body{padding:32px 36px 36px}.signup-section-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);align-items:center;gap:8px;margin-bottom:16px;font-size:11px;font-weight:700;display:flex}.signup-section-title:after{content:"";background:var(--border-light);flex:1;height:1px}.signup-loginid-section{margin-bottom:24px}.signup-loginid-row{align-items:flex-start;gap:10px;display:flex}.signup-loginid-input-wrap{flex:1;position:relative}.signup-input{border:1.5px solid var(--border-medium);border-radius:var(--radius-md);width:100%;height:46px;font-size:14px;font-family:var(--font-sans);color:var(--text-primary);background:var(--bg-input);transition:var(--transition-fast);outline:none;padding:0 14px 0 42px}.signup-input::placeholder{color:var(--text-muted)}.signup-input:hover{border-color:var(--black-300)}.signup-input:focus{border-color:var(--red-500);box-shadow:0 0 0 3px #e61a271a}.signup-input.available{border-color:var(--success-text);box-shadow:0 0 0 3px #16a34a1a}.signup-input.unavailable{border-color:var(--error-text);box-shadow:0 0 0 3px #dc26261a}.signup-input.disabled-input{background:var(--black-50);color:var(--text-muted);cursor:not-allowed}.signup-input-prefix-icon{color:var(--text-muted);pointer-events:none;font-size:15px;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.signup-check-btn{background:var(--red-500);height:46px;color:var(--white);border-radius:var(--radius-md);font-size:13.5px;font-weight:700;font-family:var(--font-sans);cursor:pointer;white-space:nowrap;transition:var(--transition-base);box-shadow:var(--shadow-red);border:none;flex-shrink:0;align-items:center;gap:6px;padding:0 20px;display:flex}.signup-check-btn:hover:not(:disabled){background:var(--red-600)}.signup-check-btn:disabled{opacity:.5;cursor:not-allowed}.signup-avail-badge{border-radius:var(--radius-full);align-items:center;gap:6px;margin-top:8px;padding:4px 10px;font-size:12.5px;font-weight:600;display:inline-flex}.signup-avail-badge.available{background:var(--success-bg);color:var(--success-text);border:1px solid var(--success-border)}.signup-avail-badge.unavailable{background:var(--error-bg);color:var(--error-text);border:1px solid var(--error-border)}.signup-form{flex-direction:column;gap:18px;display:flex}.signup-form-grid{grid-template-columns:1fr 1fr;gap:14px;display:grid}.signup-field{flex-direction:column;gap:6px;display:flex}.signup-field label{color:var(--text-secondary);letter-spacing:.01em;font-size:12.5px;font-weight:600}.signup-field-error{color:var(--error-text);align-items:center;gap:4px;font-size:11.5px;display:flex}.signup-input.error{border-color:var(--error-text);box-shadow:0 0 0 3px #dc26261a}.signup-modules-grid{grid-template-columns:1fr 1fr;gap:8px;margin-top:4px;display:grid}.signup-module-chip{border:1.5px solid var(--border-medium);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-fast);background:var(--white);-webkit-user-select:none;user-select:none;align-items:center;gap:10px;padding:10px 14px;display:flex}.signup-module-chip:hover{border-color:var(--red-400);background:var(--red-50)}.signup-module-chip.selected{border-color:var(--red-500);background:var(--red-50)}.signup-module-chip input[type=checkbox]{accent-color:var(--red-500);cursor:pointer;flex-shrink:0;width:15px;height:15px}.signup-module-chip span{color:var(--text-primary);font-size:13px;font-weight:500;line-height:1.3}.signup-module-chip.selected span{color:var(--red-700);font-weight:600}.signup-module-skeleton{border-radius:var(--radius-md);height:42px}.signup-gated{transition:opacity .25s}.signup-gated.locked{opacity:.4;pointer-events:none;-webkit-user-select:none;user-select:none}.signup-lock-notice{background:var(--red-50);border:1px solid var(--red-100);border-radius:var(--radius-md);color:var(--red-700);align-items:center;gap:8px;margin-bottom:20px;padding:10px 14px;font-size:12.5px;display:flex}.signup-submit-btn{background:var(--red-500);width:100%;height:48px;color:var(--white);border-radius:var(--radius-md);font-size:15px;font-weight:700;font-family:var(--font-sans);cursor:pointer;transition:var(--transition-base);box-shadow:var(--shadow-red);border:none;justify-content:center;align-items:center;gap:8px;margin-top:8px;display:flex}.signup-submit-btn:hover:not(:disabled){background:var(--red-600);box-shadow:var(--shadow-red-lg);transform:translateY(-1px)}.signup-submit-btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.signup-success{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:48px 24px;animation:.3s fadeIn;display:flex}.signup-success-icon{background:var(--success-bg);border:2px solid var(--success-border);border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;font-size:32px;display:flex}.signup-success h3{color:var(--text-primary);font-size:22px;font-weight:800}.signup-success p{color:var(--text-muted);max-width:320px;font-size:14px;line-height:1.6}.signup-footer-link{text-align:center;color:var(--text-muted);margin-top:24px;font-size:13.5px}.signup-footer-link a{color:var(--red-500);margin-left:4px;font-weight:600}.signup-footer-link a:hover{color:var(--red-700);text-decoration:underline}.signup-spinner{border:2.5px solid #ffffff59;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin}@media (width<=600px){.signup-body{padding:24px 20px 28px}.signup-header{padding:22px 20px 18px}.signup-form-grid,.signup-modules-grid{grid-template-columns:1fr}}.btn{font-family:var(--font-sans);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-base);white-space:nowrap;letter-spacing:.01em;border:none;outline:none;justify-content:center;align-items:center;gap:7px;font-weight:600;text-decoration:none;display:inline-flex;position:relative;overflow:hidden}.btn:focus-visible{outline:2px solid var(--red-500);outline-offset:2px}.btn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none!important;transform:none!important}.btn-sm{border-radius:var(--radius-sm);height:34px;padding:0 14px;font-size:12.5px}.btn-md{height:42px;padding:0 20px;font-size:14px}.btn-lg{border-radius:var(--radius-lg);height:50px;padding:0 28px;font-size:15px}.btn-primary{background:var(--red-500);color:var(--white);box-shadow:var(--shadow-red)}.btn-primary:hover:not(:disabled){background:var(--red-600);box-shadow:var(--shadow-red-lg);transform:translateY(-1px)}.btn-primary:active:not(:disabled){box-shadow:var(--shadow-red);transform:translateY(0)}.btn-secondary{background:var(--black-900);color:var(--white);box-shadow:var(--shadow-sm)}.btn-secondary:hover:not(:disabled){background:var(--black-700);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-secondary:active:not(:disabled){transform:translateY(0)}.btn-danger{background:var(--error-bg);color:var(--error-text);border:1.5px solid var(--error-border)}.btn-danger:hover:not(:disabled){background:var(--error-text);color:var(--white);border-color:var(--error-text);transform:translateY(-1px)}.btn-ghost{color:var(--text-secondary);border:1.5px solid var(--border-medium);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--black-50);border-color:var(--black-300);color:var(--text-primary)}.btn-outline{color:var(--red-500);border:1.5px solid var(--red-500);background:0 0}.btn-outline:hover:not(:disabled){background:var(--red-500);color:var(--white);box-shadow:var(--shadow-red);transform:translateY(-1px)}.btn-full{width:100%}.btn-icon{border-radius:var(--radius-md);width:34px;height:34px;padding:0;font-size:16px}.btn-icon.btn-md{width:42px;height:42px}.btn-spinner{border:2px solid #fff6;border-top-color:currentColor;border-radius:50%;flex-shrink:0;width:15px;height:15px;animation:.65s linear infinite btn-spin}.btn-secondary .btn-spinner,.btn-ghost .btn-spinner,.btn-outline .btn-spinner,.btn-danger .btn-spinner{border-color:currentColor #0003 #0003}@keyframes btn-spin{to{transform:rotate(360deg)}}.modal-overlay{background:var(--bg-overlay);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:var(--z-modal);justify-content:center;align-items:center;padding:20px;animation:.18s forwards modal-fade;display:flex;position:fixed;inset:0}@keyframes modal-fade{0%{opacity:0}to{opacity:1}}.modal-box{background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);border:1px solid var(--border-light);width:100%;max-height:90vh;animation:.2s forwards modal-slide;overflow-y:auto}@keyframes modal-slide{0%{opacity:0;transform:scale(.96)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-sm{max-width:400px}.modal-md{max-width:560px}.modal-lg{max-width:720px}.modal-xl{max-width:900px}.modal-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:flex-start;gap:16px;padding:22px 24px 18px;display:flex}.modal-title{color:var(--text-primary);letter-spacing:-.2px;margin-bottom:3px;font-size:17px;font-weight:800}.modal-subtitle{color:var(--text-muted);font-size:12.5px}.modal-close{background:var(--black-50);border-radius:var(--radius-md);cursor:pointer;width:32px;height:32px;color:var(--text-muted);transition:var(--transition-fast);border:none;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;display:flex}.modal-close:hover{background:var(--black-100);color:var(--text-primary)}.modal-body{padding:24px}.modal-footer{border-top:1px solid var(--border-light);background:var(--black-50);border-radius:0 0 var(--radius-xl) var(--radius-xl);justify-content:flex-end;align-items:center;gap:10px;padding:16px 24px;display:flex}.modal-confirm-icon{border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;margin:0 auto 16px;font-size:24px;display:flex}.modal-confirm-icon.danger{background:var(--error-bg)}.modal-confirm-icon.warning{background:var(--warning-bg)}.modal-confirm-icon.success{background:var(--success-bg)}.modal-confirm-body{text-align:center;padding:8px 0 4px}.modal-confirm-body h4{margin-bottom:8px;font-size:17px;font-weight:800}.modal-confirm-body p{color:var(--text-muted);font-size:13.5px;line-height:1.6}.sidebar{height:100vh;width:var(--sidebar-width);background:var(--bg-sidebar);z-index:var(--z-sticky);border-right:1px solid var(--sidebar-border);flex-direction:column;transition:width .24s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;left:0;overflow:hidden}.sidebar.collapsed{width:var(--sidebar-collapsed)}.sidebar-brand{height:var(--navbar-height);border-bottom:1px solid var(--sidebar-border);flex-shrink:0;align-items:center;gap:11px;padding:0 16px;text-decoration:none;display:flex;overflow:hidden}.sidebar-brand-icon{background:var(--red-500);width:36px;height:36px;box-shadow:var(--shadow-red);border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;display:flex}.sidebar-brand-text{white-space:nowrap;flex-direction:column;transition:opacity .18s;display:flex;overflow:hidden}.sidebar.collapsed .sidebar-brand-text{opacity:0}.sidebar-brand-name{color:var(--text-primary);letter-spacing:-.2px;font-size:14px;font-weight:800;line-height:1.2}.sidebar-brand-sub{color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;font-size:9.5px;font-weight:600}.sidebar-nav{scrollbar-width:thin;scrollbar-color:var(--black-200) transparent;flex:1;padding:10px 0 16px;overflow:hidden auto}.sidebar-nav::-webkit-scrollbar{width:5px}.sidebar-nav::-webkit-scrollbar-track{background:0 0}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--black-200);border-radius:10px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:var(--black-300)}.sidebar-group{margin-bottom:2px}.sidebar-group-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);white-space:nowrap;background:var(--bg-sidebar);z-index:2;padding:12px 20px 5px;font-size:10px;font-weight:700;position:sticky;top:0;overflow:hidden}.sidebar.collapsed .sidebar-group-label{opacity:0;height:14px;padding:7px 0 0}.sidebar.collapsed .sidebar-group:not(:first-child):before{content:"";background:var(--sidebar-border);height:1px;margin:6px 14px;display:block}.sidebar-item{border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;align-items:center;gap:11px;margin:1px 10px;padding:9px 14px;text-decoration:none;transition:background .13s,color .13s;display:flex;position:relative}.sidebar-item:hover{background:var(--bg-sidebar-hover)}.sidebar-item.active{background:var(--red-500);box-shadow:var(--shadow-red)}.sidebar-item-icon{width:20px;height:20px;color:var(--black-400);flex-shrink:0;justify-content:center;align-items:center;font-size:16px;transition:color .13s;display:flex}.sidebar-item:hover .sidebar-item-icon{color:var(--text-primary)}.sidebar-item.active .sidebar-item-icon{color:var(--white)}.sidebar-item-label{color:var(--text-secondary);text-overflow:ellipsis;font-size:13.5px;font-weight:500;transition:opacity .18s,color .13s;overflow:hidden}.sidebar-item:hover .sidebar-item-label{color:var(--text-primary)}.sidebar-item.active .sidebar-item-label{color:var(--white);font-weight:600}.sidebar.collapsed .sidebar-item-label{opacity:0;width:0}.sidebar.collapsed .sidebar-item{justify-content:center;margin:2px 10px;padding:10px}.sidebar.collapsed .sidebar-item:hover:after{content:attr(data-label);background:var(--black-900);color:var(--white);border-radius:var(--radius-md);white-space:nowrap;z-index:999;pointer-events:none;box-shadow:var(--shadow-lg);padding:6px 11px;font-size:12px;font-weight:600;position:absolute;top:50%;left:calc(100% + 14px);transform:translateY(-50%)}.sidebar.collapsed .sidebar-item:hover:before{content:"";border:5px solid #0000;border-right-color:var(--black-900);z-index:999;pointer-events:none;position:absolute;top:50%;left:calc(100% + 8px);transform:translateY(-50%)}.sidebar-user{border-top:1px solid var(--sidebar-border);flex-shrink:0;align-items:center;gap:10px;padding:12px 16px;display:flex;overflow:hidden}.sidebar-user-avatar{background:var(--red-500);width:34px;height:34px;color:var(--white);text-transform:uppercase;box-shadow:var(--shadow-red);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:800;display:flex}.sidebar-user-info{white-space:nowrap;flex:1;transition:opacity .18s;overflow:hidden}.sidebar.collapsed .sidebar-user-info{opacity:0;width:0}.sidebar-user-name{color:var(--text-primary);text-overflow:ellipsis;font-size:13px;font-weight:700;overflow:hidden}.sidebar-user-id{color:var(--text-muted);text-overflow:ellipsis;font-size:11px;overflow:hidden}.sidebar-logout-btn{cursor:pointer;color:var(--text-muted);border-radius:var(--radius-sm);transition:var(--transition-fast);background:0 0;border:none;flex-shrink:0;align-items:center;padding:5px;font-size:16px;display:flex}.sidebar-logout-btn:hover{color:var(--red-500);background:var(--red-50)}.sidebar.collapsed .sidebar-logout-btn{display:none}.sidebar-toggle{border-top:1px solid var(--sidebar-border);cursor:pointer;height:44px;transition:var(--transition-fast);color:var(--text-muted);flex-shrink:0;justify-content:center;align-items:center;font-size:18px;display:flex}.sidebar-toggle:hover{background:var(--bg-sidebar-hover);color:var(--red-500)}.sidebar-divider{display:none}.sidebar-mobile-overlay{z-index:calc(var(--z-sticky) - 1);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#18181b80;display:none;position:fixed;inset:0}.sidebar-dropdown{margin:2px 0}.sidebar-dropdown-toggle{cursor:pointer;width:calc(100% - 20px);font-family:var(--font-sans);text-align:left;background:0 0;border:none}.sidebar-dropdown-toggle.active-parent{background:var(--red-50)}.sidebar-dropdown-toggle.active-parent .sidebar-item-icon,.sidebar-dropdown-toggle.active-parent .sidebar-item-label{color:var(--red-600)}.sidebar-dropdown-arrow{color:var(--text-muted);align-items:center;margin-left:auto;transition:transform .2s;display:flex}.sidebar-dropdown.open .sidebar-dropdown-arrow{transform:rotate(180deg)}.sidebar-dropdown-menu{max-height:0;transition:max-height .28s cubic-bezier(.4,0,.2,1);overflow:hidden}.sidebar-dropdown.open .sidebar-dropdown-menu{max-height:700px}.sidebar-subitem{position:relative;margin:1px 10px 1px 18px!important;padding-left:30px!important}.sidebar-subitem .sidebar-item-icon{font-size:15px}.sidebar-subitem .sidebar-item-label{font-size:13px}.sidebar-dropdown-menu:before{content:"";background:var(--border-light);width:1px;position:absolute;left:27px}.sidebar.collapsed .sidebar-dropdown-arrow{display:none}.sidebar.collapsed .sidebar-dropdown-menu{background:var(--white);border:1px solid var(--border-light);border-radius:var(--radius-md);width:210px;max-height:none;box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;z-index:999;padding:6px;transition:opacity .15s,transform .15s,visibility .15s;position:absolute;top:0;left:calc(100% + 8px);transform:translate(-6px)}.sidebar.collapsed .sidebar-dropdown{position:relative}.sidebar.collapsed .sidebar-dropdown:hover .sidebar-dropdown-menu{opacity:1;visibility:visible;transform:translate(0)}.sidebar.collapsed .sidebar-dropdown-menu .sidebar-item-label{opacity:1!important;width:auto!important}.sidebar.collapsed .sidebar-subitem{justify-content:flex-start!important;margin:1px 0!important;padding-left:12px!important}.sidebar.collapsed .sidebar-dropdown-menu:before{display:none}.sidebar.collapsed .sidebar-dropdown-menu:after{content:attr(data-flyout-label)}@media (width<=768px){.sidebar{z-index:var(--z-modal);box-shadow:var(--shadow-xl);transition:transform .24s;transform:translate(-100%);width:var(--sidebar-width)!important}.sidebar.mobile-open{transform:translate(0)}.sidebar-mobile-overlay{display:block}}.navbar{height:var(--navbar-height);background:var(--bg-navbar);border-bottom:1px solid var(--border-light);z-index:calc(var(--z-sticky) - 1);box-shadow:var(--shadow-xs);justify-content:space-between;align-items:center;padding:0 24px;transition:left .24s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;right:0}.navbar:before{content:"";background:linear-gradient(90deg, var(--red-500), var(--red-700));height:3px;display:block;position:absolute;top:0;left:0;right:0}.navbar-left{align-items:center;gap:16px;display:flex}.navbar-hamburger{cursor:pointer;color:var(--text-secondary);border-radius:var(--radius-sm);transition:var(--transition-fast);background:0 0;border:none;padding:4px;font-size:22px;line-height:1;display:none}.navbar-hamburger:hover{color:var(--red-500)}@media (width<=768px){.navbar-hamburger{align-items:center;display:flex}}.navbar-page-title{color:var(--text-primary);align-items:center;gap:8px;font-size:16px;font-weight:700;display:flex}.navbar-page-title span.page-icon{font-size:18px}.navbar-breadcrumb{color:var(--text-muted);align-items:center;gap:6px;margin-top:1px;font-size:12px;display:flex}.navbar-breadcrumb span{color:var(--text-muted)}.navbar-breadcrumb strong{color:var(--text-secondary);font-weight:500}.navbar-right{align-items:center;gap:12px;display:flex}.navbar-datetime{color:var(--text-secondary);background:var(--black-50);border-radius:var(--radius-full);border:1px solid var(--border-light);white-space:nowrap;align-items:center;gap:6px;padding:6px 13px;font-size:12px;font-weight:500;display:flex}@media (width<=640px){.navbar-datetime{display:none}}.navbar-user{background:var(--white);border:1px solid var(--border-light);border-radius:var(--radius-full);cursor:default;transition:var(--transition-fast);align-items:center;gap:9px;padding:5px 14px 5px 6px;display:flex}.navbar-user:hover{border-color:var(--red-300);box-shadow:var(--shadow-xs)}.navbar-user-avatar{background:var(--red-500);width:28px;height:28px;color:var(--white);text-transform:uppercase;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:800;display:flex}.navbar-user-name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;max-width:120px;font-size:13px;font-weight:600;overflow:hidden}@media (width<=480px){.navbar-user-name{display:none}}.admin-layout{background:var(--bg-app);min-height:100vh;display:flex}.admin-main{flex-direction:column;flex:1;min-height:100vh;transition:margin-left .24s cubic-bezier(.4,0,.2,1);display:flex}.admin-main.sidebar-expanded{margin-left:var(--sidebar-width)}.admin-main.sidebar-collapsed{margin-left:var(--sidebar-collapsed)}.admin-content{padding:calc(var(--navbar-height) + 24px) 28px 32px;flex:1;max-width:100%;animation:.2s forwards fadeIn}.admin-page-card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-light);box-shadow:var(--shadow-sm);overflow:hidden}.stats-row{grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);border-left:3px solid var(--red-500);box-shadow:var(--shadow-sm);transition:var(--transition-base);align-items:center;gap:15px;padding:18px 20px;display:flex}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;font-size:21px;display:flex}.stat-card-value{color:var(--text-primary);letter-spacing:-.5px;font-size:26px;font-weight:900;line-height:1.1}.stats-row .stat-card:nth-child(2){border-left-color:var(--black-900)}.stats-row .stat-card:nth-child(3){border-left-color:var(--success-text)}.stats-row .stat-card:nth-child(4){border-left-color:var(--info-text)}.table-toolbar{border-bottom:1px solid var(--border-light);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex}.table-toolbar-left{flex:1;align-items:center;gap:10px;min-width:200px;display:flex}.table-toolbar-right{align-items:center;gap:8px;display:flex}.table-search{flex:1;max-width:340px;position:relative}.table-search input{border:1.5px solid var(--border-medium);border-radius:var(--radius-md);width:100%;height:38px;font-size:13.5px;font-family:var(--font-sans);color:var(--text-primary);background:var(--white);transition:var(--transition-fast);outline:none;padding:0 14px 0 38px}.table-search input::placeholder{color:var(--text-muted)}.table-search input:focus{border-color:var(--red-500);box-shadow:0 0 0 3px #e61a271a}.table-search-icon{color:var(--text-muted);pointer-events:none;font-size:15px;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.record-count{color:var(--text-secondary);background:var(--black-50);border-radius:var(--radius-full);border:1px solid var(--border-light);white-space:nowrap;padding:5px 11px;font-size:12px;font-weight:600}@media (width<=768px){.admin-main.sidebar-expanded,.admin-main.sidebar-collapsed{margin-left:0}.admin-content{padding:calc(var(--navbar-height) + 16px) 16px 24px}}.loader-fullpage{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-overlay);background:#ffffffd9;flex-direction:column;justify-content:center;align-items:center;gap:14px;display:flex;position:fixed;inset:0}.loader-inline{justify-content:center;align-items:center;gap:12px;padding:40px 20px;display:flex}.loader-spinner{border:3px solid var(--border-light);border-top-color:var(--red-500);border-radius:50%;flex-shrink:0;animation:.75s linear infinite loader-spin}.loader-sm .loader-spinner{border-width:2px;width:20px;height:20px}.loader-md .loader-spinner{width:32px;height:32px}.loader-lg .loader-spinner{border-width:4px;width:48px;height:48px}@keyframes loader-spin{to{transform:rotate(360deg)}}.loader-text{color:var(--text-muted);font-size:13.5px;font-weight:500}.loader-table-skeleton{flex-direction:column;gap:10px;padding:16px;display:flex}.loader-skeleton-row{align-items:center;gap:12px;display:grid}.loader-skeleton-cell{border-radius:var(--radius-sm);height:14px}.badge{border-radius:var(--radius-full);letter-spacing:.03em;white-space:nowrap;border:1px solid #0000;align-items:center;gap:5px;padding:3px 10px;font-size:11.5px;font-weight:700;display:inline-flex}.badge-pending{background:var(--badge-pending-bg);color:var(--badge-pending-text);border-color:var(--warning-border)}.badge-approved,.badge-active{background:var(--badge-approved-bg);color:var(--badge-approved-text);border-color:var(--success-border)}.badge-rejected,.badge-error{background:var(--badge-rejected-bg);color:var(--badge-rejected-text);border-color:var(--error-border)}.badge-disabled,.badge-inactive{background:var(--badge-disabled-bg);color:var(--badge-disabled-text);border-color:var(--border-medium)}.badge-info{background:var(--info-bg);color:var(--info-text);border-color:var(--info-border)}.badge-red{background:var(--red-100);color:var(--red-700);border-color:var(--red-300)}.badge-dark{background:var(--black-900);color:var(--white);border-color:var(--black-900)}.badge-dot{background:currentColor;border-radius:50%;flex-shrink:0;width:6px;height:6px}.dashboard-root{flex-direction:column;gap:22px;display:flex}.dashboard-banner{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);justify-content:space-between;align-items:center;gap:20px;padding:24px 28px;display:flex;position:relative;overflow:hidden}.dashboard-banner:before{content:"";background:linear-gradient(180deg, var(--red-500), var(--red-700));width:4px;position:absolute;top:0;bottom:0;left:0}.dashboard-banner:after{content:"";pointer-events:none;background:radial-gradient(circle,#c8102e1a 0%,#c8102e00 70%);border-radius:50%;width:340px;height:340px;position:absolute;top:-120px;right:-80px}.dashboard-banner-grid{pointer-events:none;opacity:.5;background-image:linear-gradient(#c8102e09 1px,#0000 1px),linear-gradient(90deg,#c8102e09 1px,#0000 1px);background-size:34px 34px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(circle at 80% 0,#000,#0000 60%);mask-image:radial-gradient(circle at 80% 0,#000,#0000 60%)}.dashboard-banner-left{z-index:1}.dashboard-banner-tag{background:var(--red-50);border:1px solid var(--red-100);color:var(--red-600);letter-spacing:.08em;text-transform:uppercase;border-radius:var(--radius-full);align-items:center;gap:6px;margin-bottom:12px;padding:4px 11px;font-size:10.5px;font-weight:700;display:inline-flex}.dashboard-banner-tag:before{content:"";background:var(--red-500);border-radius:50%;width:5px;height:5px;animation:2s infinite pulse-dot}.dashboard-banner h2{color:var(--text-primary);letter-spacing:-.4px;margin-bottom:6px;font-size:25px;font-weight:900;line-height:1.2}.dashboard-banner h2 em{color:var(--red-500);font-style:normal}.dashboard-banner p{color:var(--text-secondary);max-width:420px;font-size:13px;line-height:1.6}.dashboard-banner-right{z-index:1;text-align:right;flex-direction:column;align-items:flex-end;gap:5px;display:flex}.dashboard-banner-date{color:var(--text-muted);font-size:12.5px;font-weight:500}.dashboard-banner-time{color:var(--text-primary);letter-spacing:-1px;font-variant-numeric:tabular-nums;font-size:30px;font-weight:900;line-height:1}.dashboard-banner-version{color:var(--red-600);background:var(--red-50);border-radius:var(--radius-full);border:1px solid var(--red-100);padding:3px 10px;font-size:10.5px;font-weight:600}.dashboard-stats-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);align-items:center;gap:9px;margin-bottom:13px;font-size:11.5px;font-weight:700;display:flex}.dashboard-stats-title:after{content:"";background:var(--border-light);flex:1;height:1px}.stats-row{grid-template-columns:repeat(4,1fr);gap:14px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:var(--transition-base);align-items:center;gap:14px;padding:16px 18px;display:flex;position:relative;overflow:hidden}.stat-card:after{content:"";background:var(--red-50);opacity:0;width:90px;height:90px;transition:var(--transition-base);border-radius:50%;position:absolute;top:-30px;right:-30px}.stat-card:hover{box-shadow:var(--shadow-md);border-color:var(--red-200);transform:translateY(-3px)}.stat-card:hover:after{opacity:.5}.stat-card-icon{border-radius:var(--radius-md);z-index:1;background:var(--red-50);flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;font-size:21px;display:flex}.stat-card-icon.red{background:var(--red-50)}.stat-card-icon.dark{background:var(--black-50,#f2f2f4)}.stat-card-icon.green{background:var(--green-50,var(--red-50))}.stat-card-icon.blue{background:var(--blue-50,var(--black-50,#eef1f6))}.stat-card-body{z-index:1}.stat-card-value{color:var(--text-primary);letter-spacing:-.6px;font-variant-numeric:tabular-nums;font-size:26px;font-weight:900;line-height:1}.stat-card-label{color:var(--text-muted);margin-top:4px;font-size:11.5px;font-weight:600}.dashboard-actions{grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:13px;display:grid}.dashboard-action-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);cursor:pointer;transition:var(--transition-base);align-items:center;gap:13px;padding:15px 17px;text-decoration:none;display:flex;position:relative;overflow:hidden}.dashboard-action-card:before{content:"";background:var(--red-500);transform-origin:50%;width:3px;transition:transform .2s;position:absolute;top:0;bottom:0;left:0;transform:scaleY(0)}.dashboard-action-card:hover{border-color:var(--red-200);box-shadow:var(--shadow-md);transform:translateY(-2px)}.dashboard-action-card:hover:before{transform:scaleY(1)}.dashboard-action-icon{border-radius:var(--radius-md);background:var(--red-50);width:42px;height:42px;transition:var(--transition-base);flex-shrink:0;justify-content:center;align-items:center;font-size:20px;display:flex}.dashboard-action-card:hover .dashboard-action-icon{background:var(--red-100);transform:scale(1.06)}.dashboard-action-label{color:var(--text-primary);margin-bottom:2px;font-size:13.5px;font-weight:700}.dashboard-action-desc{color:var(--text-muted);font-size:11.5px}.dashboard-bottom{grid-template-columns:1fr 1fr;gap:18px;display:grid}.dashboard-info-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.dashboard-info-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.dashboard-info-title{color:var(--text-primary);align-items:center;gap:8px;font-size:13.5px;font-weight:800;display:flex}.dashboard-info-body{flex-direction:column;gap:10px;padding:14px 18px;display:flex}.dashboard-info-row{background:var(--bg-app);border-radius:var(--radius-md);border:1px solid var(--border-light);transition:var(--transition-fast);justify-content:space-between;align-items:center;padding:10px 13px;display:flex}.dashboard-info-row:hover{border-color:var(--red-200);background:var(--red-50)}.dashboard-info-row-left{align-items:center;gap:10px;display:flex}.dashboard-info-row-icon{border-radius:var(--radius-sm);background:var(--white);border:1px solid var(--border-light);justify-content:center;align-items:center;width:32px;height:32px;font-size:15px;display:flex}.dashboard-info-row-label{color:var(--text-primary);font-size:13px;font-weight:600}.dashboard-info-row-sub{color:var(--text-muted);font-size:11px}@media (width<=900px){.dashboard-bottom{grid-template-columns:1fr}.stats-row{grid-template-columns:1fr 1fr}}@media (width<=600px){.stats-row{grid-template-columns:1fr 1fr}.dashboard-banner{flex-direction:column;align-items:flex-start;gap:16px}.dashboard-banner-right{text-align:left;align-items:flex-start}.dashboard-banner-time{font-size:24px}}.input-wrapper{flex-direction:column;gap:6px;display:flex}.input-label{color:var(--text-secondary);letter-spacing:.01em;align-items:center;gap:4px;font-size:12.5px;font-weight:600;display:flex}.input-required{color:var(--red-500);font-size:13px;line-height:1}.input-field-wrap{align-items:center;display:flex;position:relative}.input-field{background:var(--bg-input);border:1.5px solid var(--border-medium);border-radius:var(--radius-md);width:100%;height:44px;font-size:14px;font-family:var(--font-sans);color:var(--text-primary);transition:var(--transition-fast);appearance:none;outline:none;padding:0 14px}.input-field::placeholder{color:var(--black-300);font-weight:400}.input-field:hover:not(:disabled){border-color:var(--black-300)}.input-field:focus{border-color:var(--red-500);background:var(--white);box-shadow:0 0 0 3px #f400001a}.input-field:disabled{background:var(--black-50);color:var(--text-muted);cursor:not-allowed;border-color:var(--border-light)}.input-sm .input-field{height:36px;font-size:13px}.input-lg .input-field{height:50px;font-size:15px}.input-has-prefix .input-field{padding-left:40px}.input-has-suffix .input-field{padding-right:40px}.input-prefix-icon,.input-suffix-icon{color:var(--black-300);pointer-events:none;transition:var(--transition-fast);align-items:center;font-size:15px;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.input-prefix-icon{left:13px}.input-suffix-icon{pointer-events:all;right:13px}.input-field-wrap:focus-within .input-prefix-icon{color:var(--red-500)}.input-field.input-error{border-color:var(--error-text);box-shadow:0 0 0 3px #dc262614}.input-error-msg{color:var(--error-text);align-items:center;gap:4px;font-size:11.5px;font-weight:500;display:flex}.input-helper{color:var(--text-muted);font-size:11.5px}select.input-field{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238A8A8A' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;padding-right:36px}textarea.input-field{resize:vertical;height:auto;min-height:90px;padding:12px 14px;line-height:1.6}.area-root{flex-direction:column;gap:16px;display:flex}.area-form-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.area-form-header{border-bottom:1px solid var(--border-light);background:var(--white);align-items:center;gap:11px;padding:13px 18px;display:flex;position:relative;overflow:hidden}.area-form-header:before{content:"";background:linear-gradient(90deg, var(--red-500), var(--red-700));height:3px;position:absolute;top:0;left:0;right:0}.area-form-header-icon{background:var(--red-50);width:32px;height:32px;color:var(--red-600);border:1px solid var(--red-100);border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;font-size:16px;display:flex}.area-form-header-text h3{color:var(--text-primary);margin-bottom:1px;font-size:14px;font-weight:800}.area-form-header-text p{color:var(--text-muted);font-size:11.5px}.area-form-body{padding:16px 18px}.area-form-grid{grid-template-columns:1fr 1fr 1fr;gap:13px;margin-bottom:14px;display:grid}.area-form-actions{border-top:1px solid var(--border-light);justify-content:flex-end;align-items:center;gap:9px;padding-top:13px;display:flex}.area-table-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.area-table{border-collapse:collapse;width:100%;font-size:13px}.area-table thead tr{background:var(--bg-table-head)}.area-table thead th{text-align:left;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);white-space:nowrap;padding:9px 14px;font-size:10.5px;font-weight:700}.area-table thead th:first-child{width:54px;padding-left:18px}.area-table thead th:last-child{padding-right:18px}.area-table tbody tr{border-bottom:1px solid var(--border-light);transition:var(--transition-fast)}.area-table tbody tr:last-child{border-bottom:none}.area-table tbody tr:hover{background:var(--bg-table-hover)}.area-table tbody td{color:var(--text-primary);vertical-align:middle;padding:9px 14px}.area-table tbody td:first-child{padding-left:18px;position:relative}.area-table tbody td:last-child{padding-right:18px}.area-table tbody tr:hover td:first-child:before{content:"";background:var(--red-500);width:3px;position:absolute;top:0;bottom:0;left:0}.area-table .td-id{color:var(--text-muted);font-variant-numeric:tabular-nums;font-size:11.5px;font-weight:700}.area-table .td-state{font-weight:600}.area-table .td-city{color:var(--text-secondary);font-weight:600}.area-state-cell{align-items:center;gap:7px;display:flex}.area-state-dot{background:var(--red-500);border-radius:50%;flex-shrink:0;width:7px;height:7px}.area-pill{background:var(--red-50);color:var(--red-700);border-radius:var(--radius-full);border:1px solid var(--red-100);padding:3px 11px;font-size:12px;font-weight:600;display:inline-block}.area-count-chip{color:var(--red-700);background:var(--red-50);border:1px solid var(--red-100);border-radius:var(--radius-full);padding:2px 9px;font-size:11px;font-weight:700}.area-filter-select{border:1.5px solid var(--border-medium);border-radius:var(--radius-md);height:34px;font-size:12.5px;font-family:var(--font-sans);color:var(--text-primary);background:var(--white);cursor:pointer;appearance:none;transition:var(--transition-fast);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'%3E%3Cpath fill='%238A8A8A' d='M5 7L1 3h8z'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;outline:none;min-width:142px;padding:0 30px 0 11px}.area-filter-select:hover:not(:disabled){border-color:var(--black-300)}.area-filter-select:focus{border-color:var(--red-500);box-shadow:0 0 0 3px #c8102e14}.area-filter-select:disabled{background:var(--black-50);color:var(--text-muted);cursor:not-allowed}@media (width<=768px){.area-form-grid{grid-template-columns:1fr 1fr}}@media (width<=520px){.area-form-grid{grid-template-columns:1fr}}.dealer-create-root{flex-direction:column;gap:16px;display:flex}.dealer-form-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.dealer-form-header{border-bottom:1px solid var(--border-light);background:var(--white);align-items:center;gap:11px;padding:13px 18px;display:flex;position:relative;overflow:hidden}.dealer-form-header:before{content:"";background:linear-gradient(90deg, var(--red-500), var(--red-700));height:3px;position:absolute;top:0;left:0;right:0}.dealer-form-header-icon{background:var(--red-50);width:34px;height:34px;color:var(--red-600);border:1px solid var(--red-100);border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;font-size:17px;display:flex}.dealer-form-header-text h3{color:var(--text-primary);margin-bottom:1px;font-size:14px;font-weight:800}.dealer-form-header-text p{color:var(--text-muted);font-size:11.5px}.dealer-form-body{padding:18px}.dealer-form-section{margin-bottom:18px}.dealer-form-section:last-of-type{margin-bottom:0}.dealer-form-section-title{text-transform:uppercase;letter-spacing:.08em;color:var(--red-600);align-items:center;gap:8px;margin-bottom:12px;font-size:10.5px;font-weight:700;display:flex}.dealer-form-section-title:after{content:"";background:var(--border-light);flex:1;height:1px}.dealer-form-grid-2{grid-template-columns:1fr 1fr;gap:13px;display:grid}.dealer-form-grid-3{grid-template-columns:1fr 1fr 1fr;gap:13px;display:grid}.dealer-form-full{grid-column:1/-1}.dealer-form-actions{border-top:1px solid var(--border-light);justify-content:flex-end;align-items:center;gap:9px;margin-top:18px;padding-top:16px;display:flex}.dealer-create-success{background:var(--success-bg);border:1px solid var(--success-border);border-radius:var(--radius-md);color:var(--success-text);align-items:center;gap:12px;padding:12px 16px;font-size:13px;font-weight:500;animation:.25s fadeIn;display:flex}.dealer-area-hint{color:var(--text-muted);align-items:center;gap:4px;margin-top:4px;font-size:11.5px;display:flex}@media (width<=900px){.dealer-form-grid-3{grid-template-columns:1fr 1fr}}@media (width<=600px){.dealer-form-grid-2,.dealer-form-grid-3{grid-template-columns:1fr}.dealer-form-body{padding:16px}}.pagination{border-top:1px solid var(--border-light);background:var(--white);border-radius:0 0 var(--radius-lg) var(--radius-lg);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:14px 20px;display:flex}.pagination-info{color:var(--text-muted);white-space:nowrap;font-size:12.5px}.pagination-info strong{color:var(--text-primary);font-weight:600}.pagination-controls{align-items:center;gap:4px;display:flex}.pagination-btn{border:1.5px solid var(--border-medium);background:var(--white);border-radius:var(--radius-md);min-width:34px;height:34px;font-size:13px;font-family:var(--font-sans);color:var(--text-secondary);cursor:pointer;transition:var(--transition-fast);justify-content:center;align-items:center;padding:0 10px;font-weight:600;display:flex}.pagination-btn:hover:not(:disabled){border-color:var(--red-500);color:var(--red-500);background:var(--red-50)}.pagination-btn.active{background:var(--red-500);border-color:var(--red-500);color:var(--white);box-shadow:var(--shadow-red)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-ellipsis{width:34px;height:34px;color:var(--text-muted);justify-content:center;align-items:center;font-size:13px;display:flex}.pagination-size{color:var(--text-muted);align-items:center;gap:8px;font-size:12.5px;display:flex}.pagination-size select{border:1.5px solid var(--border-medium);border-radius:var(--radius-md);height:32px;font-size:12.5px;font-family:var(--font-sans);color:var(--text-primary);background:var(--white);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'%3E%3Cpath fill='%238A8A8A' d='M5 7L1 3h8z'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;outline:none;padding:0 24px 0 10px}.pagination-size select:focus{border-color:var(--red-500)}@media (width<=600px){.pagination{justify-content:center}.pagination-info{text-align:center;width:100%}.pagination-size{display:none}}.dealer-list-root{flex-direction:column;gap:24px;display:flex}.dealer-table-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.dealer-table{border-collapse:collapse;width:100%;font-size:13.5px}.dealer-table thead tr{background:var(--bg-table-head)}.dealer-table thead th{text-align:left;text-transform:uppercase;letter-spacing:.08em;color:var(--black-300);white-space:nowrap;-webkit-user-select:none;user-select:none;padding:13px 16px;font-size:10.5px;font-weight:700}.dealer-table thead th:first-child{padding-left:20px}.dealer-table thead th:last-child{text-align:center;min-width:140px;padding-right:20px}.dealer-table tbody tr{border-bottom:1px solid var(--border-light);transition:background .12s}.dealer-table tbody tr:last-child{border-bottom:none}.dealer-table tbody tr:hover{background:var(--bg-table-hover)}.dealer-table tbody tr.row-disabled{opacity:.55}.dealer-table tbody td{vertical-align:middle;color:var(--text-primary);padding:13px 16px}.dealer-table tbody td:first-child{padding-left:20px}.dealer-table tbody td:last-child{padding-right:20px}.td-code{color:var(--text-muted);font-variant-numeric:tabular-nums;font-size:12px;font-weight:700}.td-dealer-name{color:var(--text-primary);max-width:200px;font-weight:600}.td-dealer-name-sub{color:var(--text-muted);margin-top:1px;font-size:11.5px;font-weight:400}.td-location{color:var(--text-secondary);font-size:13px}.td-location-city{color:var(--text-primary);font-weight:600}.td-mobile{font-variant-numeric:tabular-nums;color:var(--text-secondary);letter-spacing:.02em;font-size:13px}.import-template-btn{background:var(--red-50);border:1.5px solid var(--red-200);border-radius:var(--radius-md);width:100%;color:var(--red-600);font-size:13px;font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:var(--transition-fast);justify-content:center;align-items:center;gap:8px;padding:10px 14px;display:flex}.import-template-btn:hover{background:var(--red-100);border-color:var(--red-300);color:var(--red-700)}@media (width<=640px){.edit-form-grid{grid-template-columns:1fr}}.dealer-table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}@media (width<=768px){.dealer-table thead th:nth-child(5),.dealer-table tbody td:nth-child(5){display:none}}.user-list-root{flex-direction:column;gap:24px;display:flex}.user-table-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.user-table{border-collapse:collapse;width:100%;font-size:13.5px}.user-table thead tr{background:var(--bg-table-head)}.user-table thead th{text-align:left;text-transform:uppercase;letter-spacing:.08em;color:var(--black-300);white-space:nowrap;padding:13px 16px;font-size:10.5px;font-weight:700}.user-table thead th:first-child{padding-left:20px}.user-table thead th:last-child{text-align:center;min-width:140px;padding-right:20px}.user-table tbody tr{border-bottom:1px solid var(--border-light);transition:background .12s}.user-table tbody tr:last-child{border-bottom:none}.user-table tbody tr:hover{background:var(--bg-table-hover)}.user-table tbody tr.row-disabled{opacity:.55}.user-table tbody td{vertical-align:middle;color:var(--text-primary);padding:13px 16px}.user-table tbody td:first-child{padding-left:20px}.user-table tbody td:last-child{padding-right:20px}.user-cell{align-items:center;gap:11px;display:flex}.user-avatar{background:linear-gradient(135deg, var(--red-500), var(--red-700));width:36px;height:36px;color:var(--white);text-transform:uppercase;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:800;display:flex}.user-cell-name{color:var(--text-primary);font-weight:600}.user-cell-id{color:var(--text-muted);font-size:11.5px}.td-email{color:var(--text-secondary);font-size:13px}.td-mobile{font-variant-numeric:tabular-nums;color:var(--text-secondary);font-size:13px}.user-designation{flex-wrap:wrap;gap:4px;max-width:240px;display:flex}.designation-chip{background:var(--red-50);color:var(--red-700);border:1px solid var(--red-300);border-radius:var(--radius-full);white-space:nowrap;padding:2px 8px;font-size:10.5px;font-weight:600}.designation-more{background:var(--black-50);color:var(--text-muted);border-radius:var(--radius-full);padding:2px 8px;font-size:10.5px;font-weight:600}.td-actions{justify-content:center;align-items:center;gap:6px;display:flex}.action-btn{border-radius:var(--radius-sm);cursor:pointer;width:32px;height:32px;transition:var(--transition-fast);border:none;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;display:flex}.action-btn-edit{background:var(--info-bg);color:var(--info-text);border:1px solid var(--info-border)}.action-btn-edit:hover{background:var(--info-text);color:var(--white)}.action-btn-toggle{background:var(--warning-bg);color:var(--warning-text);border:1px solid var(--warning-border)}.action-btn-toggle:hover{background:var(--warning-text);color:var(--white)}.action-btn-toggle.enabled{background:var(--success-bg);color:var(--success-text);border-color:var(--success-border)}.action-btn-toggle.enabled:hover{background:var(--success-text);color:var(--white)}.action-btn-delete{background:var(--error-bg);color:var(--error-text);border:1px solid var(--error-border)}.action-btn-delete:hover{background:var(--error-text);color:var(--white)}.user-table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.edit-form-grid{grid-template-columns:1fr 1fr;gap:14px;display:grid}.edit-form-full{grid-column:1/-1}@media (width<=768px){.user-table thead th:nth-child(3),.user-table tbody td:nth-child(3),.user-table thead th:nth-child(5),.user-table tbody td:nth-child(5){display:none}}@media (width<=640px){.edit-form-grid{grid-template-columns:1fr}}.roles-root{flex-direction:column;gap:24px;display:flex}.roles-search-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px}.roles-search-row{align-items:flex-end;gap:10px;display:flex}.roles-search-input-wrap{flex:1;max-width:420px}.roles-user-card{background:var(--red-50);border:1px solid var(--red-300);border-radius:var(--radius-md);align-items:center;gap:14px;margin-top:16px;padding:16px 20px;animation:.2s fadeIn;display:flex}.roles-user-avatar{background:linear-gradient(135deg, var(--red-500), var(--red-700));width:44px;height:44px;color:var(--white);text-transform:uppercase;box-shadow:var(--shadow-red);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;font-weight:800;display:flex}.roles-user-info{flex:1}.roles-user-name{color:var(--text-primary);font-size:15px;font-weight:700}.roles-user-meta{color:var(--text-secondary);margin-top:2px;font-size:12.5px}.roles-perm-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);animation:.25s fadeIn;overflow:hidden}.roles-perm-header{border-bottom:1px solid var(--border-light);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex}.roles-perm-title{color:var(--text-primary);align-items:center;gap:8px;font-size:15px;font-weight:800;display:flex}.roles-table{border-collapse:collapse;width:100%;font-size:13.5px}.roles-table thead tr{background:var(--bg-table-head)}.roles-table thead th{text-transform:uppercase;letter-spacing:.08em;color:var(--black-300);text-align:center;padding:12px 16px;font-size:10.5px;font-weight:700}.roles-table thead th:first-child{text-align:left;padding-left:20px}.roles-table tbody tr{border-bottom:1px solid var(--border-light);transition:background .12s}.roles-table tbody tr:last-child{border-bottom:none}.roles-table tbody tr:hover{background:var(--bg-table-hover)}.roles-table tbody td{text-align:center;vertical-align:middle;padding:14px 16px}.roles-table tbody td:first-child{text-align:left;padding-left:20px}.roles-module-name{color:var(--text-primary);align-items:center;gap:8px;font-weight:600;display:flex}.roles-module-icon{border-radius:var(--radius-sm);background:var(--red-50);flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:14px;display:flex}.roles-toggle{cursor:pointer;width:42px;height:24px;display:inline-block;position:relative}.roles-toggle input{opacity:0;width:0;height:0}.roles-toggle-slider{background:var(--black-200);border-radius:var(--radius-full);transition:var(--transition-fast);position:absolute;inset:0}.roles-toggle-slider:before{content:"";background:var(--white);width:18px;height:18px;transition:var(--transition-fast);box-shadow:var(--shadow-sm);border-radius:50%;position:absolute;bottom:3px;left:3px}.roles-toggle input:checked+.roles-toggle-slider{background:var(--red-500)}.roles-toggle input:checked+.roles-toggle-slider:before{transform:translate(18px)}.roles-toggle.add input:checked+.roles-toggle-slider{background:var(--success-text)}.roles-toggle.edit input:checked+.roles-toggle-slider{background:var(--info-text)}.roles-toggle.delete input:checked+.roles-toggle-slider{background:var(--error-text)}.roles-bulk-actions{color:var(--text-muted);align-items:center;gap:8px;font-size:12px;display:flex}.roles-bulk-btn{border:1px solid var(--border-medium);background:var(--white);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);transition:var(--transition-fast);padding:4px 10px;font-size:11.5px;font-weight:600}.roles-bulk-btn:hover{border-color:var(--red-500);color:var(--red-500);background:var(--red-50)}.roles-perm-footer{border-top:1px solid var(--border-light);background:var(--black-50);justify-content:flex-end;align-items:center;gap:10px;padding:16px 20px;display:flex}@media (width<=600px){.roles-search-row{flex-direction:column;align-items:stretch}.roles-search-input-wrap{max-width:100%}}.mapping-root{flex-direction:column;gap:24px;display:flex}.mapping-select-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px}.mapping-select-row{flex-wrap:wrap;align-items:flex-end;gap:12px;display:flex}.mapping-select-field{flex:1;min-width:260px;max-width:400px}.mapping-user-banner{background:var(--red-50);border:1px solid var(--red-100);border-radius:var(--radius-md);align-items:center;gap:14px;margin-top:16px;padding:16px 18px;display:flex;position:relative;overflow:hidden}.mapping-user-banner:before{content:"";background:var(--red-500);width:4px;position:absolute;top:0;bottom:0;left:0}.mapping-user-avatar{background:var(--red-500);width:42px;height:42px;color:var(--white);text-transform:uppercase;box-shadow:var(--shadow-red);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;font-weight:800;display:flex}.mapping-user-info{flex:1}.mapping-user-name{color:var(--text-primary);font-size:15px;font-weight:700}.mapping-user-id{color:var(--text-secondary);font-size:12.5px}.mapping-user-count{text-align:right}.mapping-user-count-num{color:var(--red-500);font-size:24px;font-weight:900;line-height:1}.mapping-user-count-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:10.5px}.mapping-dealers-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);animation:.25s fadeIn;overflow:hidden}.mapping-dealers-header{border-bottom:1px solid var(--border-light);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex}.mapping-dealers-title{color:var(--text-primary);align-items:center;gap:8px;font-size:15px;font-weight:800;display:flex}.mapping-dealers-controls{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.mapping-search{width:240px;position:relative}.mapping-search input{border:1.5px solid var(--border-medium);border-radius:var(--radius-md);width:100%;height:36px;font-size:13px;font-family:var(--font-sans);transition:var(--transition-fast);outline:none;padding:0 12px 0 36px}.mapping-search input:focus{border-color:var(--red-500);box-shadow:0 0 0 3px #e61a2714}.mapping-search-icon{color:var(--text-muted);font-size:14px;position:absolute;top:50%;left:11px;transform:translateY(-50%)}.mapping-dealers-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px;max-height:480px;padding:20px;display:grid;overflow-y:auto}.mapping-dealer-item{border:1.5px solid var(--border-medium);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-fast);-webkit-user-select:none;user-select:none;background:var(--white);align-items:center;gap:12px;padding:12px 14px;display:flex}.mapping-dealer-item:hover{border-color:var(--red-400);background:var(--red-50)}.mapping-dealer-item.selected{border-color:var(--red-500);background:var(--red-50);box-shadow:0 0 0 1px var(--red-500)}.mapping-dealer-checkbox{border:2px solid var(--border-medium);border-radius:var(--radius-sm);width:20px;height:20px;transition:var(--transition-fast);background:var(--white);flex-shrink:0;justify-content:center;align-items:center;display:flex}.mapping-dealer-item.selected .mapping-dealer-checkbox{background:var(--red-500);border-color:var(--red-500);color:var(--white);font-size:12px}.mapping-dealer-body{flex:1;min-width:0}.mapping-dealer-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:13.5px;font-weight:600;overflow:hidden}.mapping-dealer-meta{color:var(--text-muted);margin-top:1px;font-size:11.5px}.mapping-dealer-code{color:var(--text-muted);background:var(--black-50);border-radius:var(--radius-full);padding:1px 6px;font-size:10.5px;font-weight:700}.mapping-footer{border-top:1px solid var(--border-light);background:var(--black-50);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex}.mapping-footer-info{color:var(--text-secondary);font-size:13px}.mapping-footer-info strong{color:var(--red-600);font-weight:700}.mapping-footer-actions{gap:10px;display:flex}@media (width<=600px){.mapping-select-row{flex-direction:column;align-items:stretch}.mapping-select-field{max-width:100%}.mapping-search{width:100%}}.mapping-list-root{flex-direction:column;gap:24px;display:flex}.mapping-list-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:18px;display:grid}.mapping-user-tile{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:var(--transition-base);overflow:hidden}.mapping-user-tile:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.mapping-tile-header{background:linear-gradient(135deg, var(--red-500) 0%, var(--red-700) 100%);align-items:center;gap:12px;padding:16px 18px;display:flex;position:relative}.mapping-tile-avatar{background:var(--white);width:38px;height:38px;color:var(--red-600);text-transform:uppercase;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:800;display:flex}.mapping-tile-info{flex:1;min-width:0}.mapping-tile-name{color:var(--white);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:700;overflow:hidden}.mapping-tile-id{color:#fffc;font-size:11.5px}.mapping-tile-badge{background:var(--white);color:var(--red-600);border-radius:var(--radius-full);white-space:nowrap;flex-shrink:0;padding:4px 10px;font-size:11px;font-weight:800}.mapping-tile-body{flex-direction:column;gap:8px;max-height:220px;padding:14px 18px;display:flex;overflow-y:auto}.mapping-dealer-row{background:var(--bg-app);border:1px solid var(--border-light);border-radius:var(--radius-md);transition:var(--transition-fast);align-items:center;gap:10px;padding:8px 12px;display:flex}.mapping-dealer-row:hover{border-color:var(--red-300);background:var(--red-50)}.mapping-dealer-row-icon{border-radius:var(--radius-sm);background:var(--white);border:1px solid var(--border-light);flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;display:flex}.mapping-dealer-row-info{flex:1;min-width:0}.mapping-dealer-row-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.mapping-dealer-row-loc{color:var(--text-muted);font-size:11px}.mapping-dealer-row-code{color:var(--text-muted);font-size:10px;font-weight:700}.approvals-root{flex-direction:column;gap:24px;display:flex}.approvals-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.approvals-table{border-collapse:collapse;width:100%;font-size:13.5px}.approvals-table thead tr{background:var(--bg-table-head)}.approvals-table thead th{text-align:left;text-transform:uppercase;letter-spacing:.08em;color:var(--black-300);padding:13px 16px;font-size:10.5px;font-weight:700}.approvals-table thead th:first-child{padding-left:20px}.approvals-table thead th:last-child{text-align:center;min-width:160px;padding-right:20px}.approvals-table tbody tr{border-bottom:1px solid var(--border-light);transition:background .12s}.approvals-table tbody tr:last-child{border-bottom:none}.approvals-table tbody tr:hover{background:var(--bg-table-hover)}.approvals-table tbody td{vertical-align:middle;padding:14px 16px}.approvals-table tbody td:first-child{padding-left:20px}.approvals-table tbody td:last-child{padding-right:20px}.approval-user-cell{align-items:center;gap:11px;display:flex}.approval-avatar{background:linear-gradient(135deg, var(--black-700), var(--black-900));width:36px;height:36px;color:var(--white);text-transform:uppercase;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:800;display:flex}.approval-name{color:var(--text-primary);font-weight:600}.approval-id{color:var(--text-muted);font-size:11.5px}.approval-modules{flex-wrap:wrap;gap:4px;max-width:220px;display:flex}.approval-module-chip{background:var(--red-50);color:var(--red-700);border:1px solid var(--red-300);border-radius:var(--radius-full);padding:2px 8px;font-size:10.5px;font-weight:600}.approval-actions{justify-content:center;align-items:center;gap:8px;display:flex}.approve-modal-user{background:var(--black-50);border-radius:var(--radius-md);align-items:center;gap:12px;margin-bottom:18px;padding:14px;display:flex}.approve-modal-user-avatar{background:linear-gradient(135deg, var(--red-500), var(--red-700));width:44px;height:44px;color:var(--white);text-transform:uppercase;border-radius:50%;justify-content:center;align-items:center;font-size:16px;font-weight:800;display:flex}.approve-modal-user-name{color:var(--text-primary);font-size:15px;font-weight:700}.approve-modal-user-meta{color:var(--text-muted);font-size:12.5px}:root{--red-500:#e61a27;--red-600:#c8141f;--red-700:#a30f19;--red-400:#f0434e;--red-300:#f47c84;--red-200:#f9b3b8;--red-100:#fce0e2;--red-50:#fef2f3;--black-900:#18181b;--black-800:#232328;--black-700:#2e2e34;--black-600:#3f3f46;--black-500:#52525b;--black-400:#71717a;--black-300:#a1a1aa;--black-200:#d4d4d8;--black-100:#e4e4e7;--black-50:#f4f4f5;--white:#fff;--bg-app:#f7f7f8;--bg-card:#fff;--bg-card-hover:#fafafa;--bg-sidebar:#fbfbfc;--bg-sidebar-hover:#f4f4f5;--bg-sidebar-active:#e61a27;--sidebar-border:#ececee;--bg-navbar:#fff;--bg-input:#fff;--bg-input-focus:#fff;--bg-table-head:#fafafa;--bg-table-row:#fff;--bg-table-alt:#fafafa;--bg-table-hover:#fef2f3;--bg-overlay:#18181b80;--text-primary:#18181b;--text-secondary:#52525b;--text-muted:#a1a1aa;--text-disabled:#d4d4d8;--text-on-red:#fff;--text-on-dark:#fff;--text-link:#e61a27;--text-link-hover:#a30f19;--border-light:#ececee;--border-medium:#dcdce0;--border-strong:#18181b;--border-focus:#e61a27;--border-error:#e61a27;--border-success:#16a34a;--success-bg:#f0fdf4;--success-text:#15803d;--success-border:#86efac;--warning-bg:#fffbeb;--warning-text:#b45309;--warning-border:#fcd34d;--error-bg:#fef2f3;--error-text:#dc2626;--error-border:#f9b3b8;--info-bg:#eff6ff;--info-text:#1d4ed8;--info-border:#bfdbfe;--badge-pending-bg:#fffbeb;--badge-pending-text:#b45309;--badge-approved-bg:#f0fdf4;--badge-approved-text:#15803d;--badge-rejected-bg:#fef2f3;--badge-rejected-text:#dc2626;--badge-active-bg:#f0fdf4;--badge-active-text:#15803d;--badge-disabled-bg:#f4f4f5;--badge-disabled-text:#71717a;--shadow-xs:0 1px 2px #18181b0a;--shadow-sm:0 1px 3px #18181b0f, 0 1px 2px #18181b0a;--shadow-md:0 4px 6px #18181b0d, 0 2px 4px #18181b0a;--shadow-lg:0 10px 15px #18181b0f, 0 4px 6px #18181b0a;--shadow-xl:0 20px 25px #18181b14, 0 8px 10px #18181b0a;--shadow-red:0 4px 14px #e61a2738;--shadow-red-lg:0 8px 25px #e61a2747;--radius-xs:3px;--radius-sm:5px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-2xl:24px;--radius-full:9999px;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--sidebar-width:248px;--sidebar-collapsed:66px;--navbar-height:60px;--content-max-width:1320px;--transition-fast:all .15s ease;--transition-base:all .2s ease;--transition-slow:all .3s ease;--z-dropdown:100;--z-sticky:200;--z-overlay:300;--z-modal:400;--z-toast:500}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;font-size:16px}body{font-family:var(--font-sans);font-size:var(--text-base);color:var(--text-primary);background:var(--bg-app);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6;overflow-x:hidden}h1,h2,h3,h4,h5,h6{color:var(--text-primary);font-weight:700;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)}p{color:var(--text-secondary);line-height:1.7}a{color:var(--text-link);transition:var(--transition-fast);text-decoration:none}a:hover{color:var(--text-link-hover)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--black-50)}::-webkit-scrollbar-thumb{background:var(--black-200);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--black-300)}::selection{background:var(--red-100);color:var(--red-700)}:focus-visible{outline:2px solid var(--red-500);outline-offset:2px}#root{flex-direction:column;min-height:100vh;display:flex}.flex{display:flex}.flex-col{flex-direction:column;display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.text-sm{font-size:var(--text-sm)}.text-xs{font-size:var(--text-xs)}.text-muted{color:var(--text-muted)}.text-red{color:var(--red-500)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-center{text-align:center}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--space-6)}.card-hover{transition:var(--transition-base);cursor:pointer}.card-hover:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.page-header{margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;display:flex}.page-title{font-size:var(--text-2xl);color:var(--text-primary);align-items:center;gap:var(--space-3);font-weight:800;display:flex}.page-title span.accent{color:var(--red-500)}.section-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:var(--space-2);font-weight:700}.divider{background:var(--border-light);height:1px;margin:var(--space-6) 0}.status-dot{border-radius:var(--radius-full);width:8px;height:8px;display:inline-block}.status-dot.active{background:var(--success-text)}.status-dot.disabled{background:var(--black-200)}.status-dot.pending{background:var(--warning-text)}.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 .empty-icon{margin-bottom:var(--space-4);opacity:.3;font-size:48px}.empty-state h3{color:var(--text-secondary);font-size:var(--text-lg);margin-bottom:var(--space-2)}.empty-state p{font-size:var(--text-sm);color:var(--text-muted)}@keyframes shimmer{0%{background-position:-600px 0}to{background-position:600px 0}}.skeleton{background:linear-gradient(90deg, var(--black-50) 25%, var(--black-100) 50%, var(--black-50) 75%);border-radius:var(--radius-sm);background-size:600px 100%;animation:1.4s infinite shimmer}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:.25s forwards fadeIn}@keyframes slideInLeft{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}.slide-in{animation:.2s forwards slideInLeft}.gradient-text{background:linear-gradient(135deg, var(--red-500), var(--red-700));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.grid-2{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.grid-3{gap:var(--space-4);grid-template-columns:1fr 1fr 1fr;display:grid}.grid-4{gap:var(--space-4);grid-template-columns:repeat(4,1fr);display:grid}@media (width<=768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}@media (width<=1024px){.grid-3,.grid-4{grid-template-columns:1fr 1fr}}
