@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--blue-600:#1a3d6b;--blue-500:#2563eb;--blue-400:#3b82f6;--blue-300:#60a5fa;--blue-200:#bfdbfe;--blue-100:#dbeafe;--blue-50:#eff6ff;--success:#059669;--success-light:#d1fae5;--warning:#d97706;--warning-light:#fef3c7;--danger:#dc2626;--danger-light:#fee2e2;--info:#2563eb;--info-light:#dbeafe;--font-body:"Inter", sans-serif;--font-mono:"JetBrains Mono", monospace;--text-xs:11px;--text-sm:13px;--text-base:15px;--text-lg:18px;--text-xl:22px;--text-2xl:28px;--text-3xl:36px;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--radius-full:9999px;--space-xs:4px;--space-sm:8px;--space-md:12px;--space-lg:16px;--space-xl:24px;--space-2xl:32px;--transition:all .15s cubic-bezier(.4, 0, .2, 1)}:root,[data-theme=light]{--bg-base:#f1f5fb;--bg-surface-1:#fff;--bg-surface-2:#f8fafd;--bg-surface-3:#eef2f8;--border-default:#d1dcf0;--border-input:#a8bedd;--border-focus:#2563eb;--text-primary:#0d1526;--text-secondary:#3d5170;--text-muted:#7a95b8;--shadow-sm:0 1px 3px #0d152612;--shadow-md:0 4px 16px #0d152617;--shadow-lg:0 8px 32px #0d15261c;--shadow-blue:0 4px 20px #2563eb26;--shadow:var(--shadow-md)}[data-theme=dark]{--bg-base:#09090b;--bg-surface-1:#18181b;--bg-surface-2:#27272a;--bg-surface-3:#3f3f46;--border-default:#27272a;--border-input:#3f3f46;--border-focus:#3b82f6;--text-primary:#fafafa;--text-secondary:#a1a1aa;--text-muted:#71717a;--shadow-sm:0 1px 3px #00000080;--shadow-md:0 4px 16px #00000073;--shadow-lg:0 8px 32px #00000080;--shadow-blue:0 4px 20px #2563eb40;--shadow:var(--shadow-md)}.btn{border-radius:var(--radius-md);font-size:var(--text-sm);cursor:pointer;white-space:nowrap;border:1.5px solid #0000;justify-content:center;align-items:center;gap:8px;padding:9px 18px;font-weight:500;transition:all .15s;display:inline-flex}.btn-primary{background-color:var(--blue-500);color:#fff;border-color:var(--blue-500);box-shadow:var(--shadow-blue)}.btn-primary:hover{background-color:var(--blue-400);border-color:var(--blue-400);transform:translateY(-1px);box-shadow:0 6px 20px #2563eb40}.btn-primary:active{background-color:var(--blue-600);transform:scale(.98)}.btn-secondary{color:var(--text-primary);border-color:var(--border-input);background-color:#0000}.btn-secondary:hover{background-color:var(--bg-surface-2);border-color:var(--text-muted)}.btn-danger{color:var(--danger);background-color:#0000;border-color:#dc262666}.btn-danger:hover{background-color:var(--danger-light);border-color:var(--danger)}.btn-danger-solid{background-color:var(--danger);color:#fff;border-color:var(--danger);box-shadow:0 4px 12px #dc262633}.btn-danger-solid:hover{filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 6px 16px #dc26264d}.btn-danger-solid:active{filter:brightness(.9);transform:scale(.98)}.btn-ghost{color:var(--text-secondary);background-color:#0000;border-color:#0000}.btn-ghost:hover{background-color:var(--bg-surface-2);color:var(--text-primary)}.btn-sm{font-size:var(--text-xs);border-radius:var(--radius-sm);padding:6px 12px}.btn-lg{font-size:var(--text-base);padding:12px 24px}.btn--loading{opacity:.7;pointer-events:none;position:relative}.btn--loading span,.btn--loading svg{visibility:hidden}.btn--loading:after{content:"";border:2px solid;border-top-color:#0000;border-radius:50%;width:16px;height:16px;animation:.6s linear infinite spin;position:absolute;top:calc(50% - 8px);left:calc(50% - 8px)}[data-tooltip]{position:relative}[data-tooltip]:before{content:"";border:4px solid #0000;border-top-color:var(--text-primary);opacity:0;visibility:hidden;pointer-events:none;z-index:1000;transition:opacity .1s,transform .1s;position:absolute;bottom:100%;left:50%;transform:translate(-50%)}[data-tooltip]:after{content:attr(data-tooltip);background-color:var(--text-primary);color:var(--bg-surface-1);border-radius:var(--radius-sm);white-space:nowrap;pointer-events:none;opacity:0;visibility:hidden;z-index:1000;padding:4px 8px;font-size:11px;font-weight:500;transition:opacity .1s,transform .1s;position:absolute;bottom:100%;left:50%;transform:translate(-50%)translateY(-4px);box-shadow:0 2px 4px #0003}[data-tooltip]:hover:after,[data-tooltip]:active:after{opacity:1;visibility:visible;transform:translate(-50%)translateY(-8px)}[data-tooltip]:hover:before,[data-tooltip]:active:before{opacity:1;visibility:visible;transform:translate(-50%)translateY(-4px)}:root{font-family:var(--font-body);color:var(--text-primary);background-color:var(--bg-base);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;font-weight:400;line-height:1.5}*{box-sizing:border-box;margin:0;padding:0;transition:background-color .15s,color .15s,border-color .15s,box-shadow .15s}body{background-color:var(--bg-base);min-width:320px;min-height:100vh;color:var(--text-primary);margin:0}#root{min-height:100vh}h1,h2,h3,h4,h5,h6{color:var(--text-primary);letter-spacing:-.025em;font-weight:700}a{color:var(--blue-500);transition:var(--transition);text-decoration:none}a:hover{color:var(--blue-400)}button{font-family:var(--font-body);cursor:pointer;background:0 0;border:none}:focus-visible{outline:2px solid var(--blue-400);outline-offset:2px;border-radius:2px}input,select,textarea{font-family:var(--font-body)}@media (width<=1024px){button,input,select{min-height:36px}.icon-btn{min-width:32px;min-height:32px}}.mono{font-family:var(--font-mono)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.text-3xl{font-size:var(--text-3xl)}.font-medium{font-weight:500}.font-bold{font-weight:700}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-danger{color:var(--danger)}.text-warning{color:var(--warning)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-base)}::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:none}}@keyframes slideInUp{0%{transform:translateY(100%)}to{transform:none}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.6)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes skeleton{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton{background:linear-gradient(90deg, var(--bg-surface-2) 25%, var(--bg-surface-3) 50%, var(--bg-surface-2) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s infinite skeleton}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}.toast-container{bottom:var(--space-xl);right:var(--space-xl);gap:var(--space-md);z-index:3000;flex-direction:column;width:calc(100% - 48px);max-width:400px;display:flex;position:fixed}.toast{background-color:var(--bg-surface-1);box-shadow:var(--shadow);border:1px solid var(--border-color);padding:var(--space-md);gap:var(--space-md);border-radius:12px;animation:.3s cubic-bezier(.4,0,.2,1) slideInRight;display:flex;position:relative;overflow:hidden}.toast:before{content:"";width:4px;position:absolute;top:0;bottom:0;left:0}.toast-success:before{background-color:var(--success)}.toast-error:before{background-color:var(--danger)}.toast-warning:before{background-color:var(--warning)}.toast-info:before{background-color:var(--blue-500)}.toast-icon{flex-shrink:0;justify-content:center;align-items:center;display:flex}.toast-success .toast-icon{color:var(--success)}.toast-error .toast-icon{color:var(--danger)}.toast-warning .toast-icon{color:var(--warning)}.toast-info .toast-icon{color:var(--blue-500)}.toast-content{flex:1;min-width:0}.toast-title{color:var(--text-primary);margin-bottom:var(--space-xs);font-size:14px;font-weight:700}.toast-message{color:var(--text-secondary);font-size:13px;line-height:1.4}.toast-close{color:var(--text-muted);transition:var(--transition);padding:var(--space-xs);flex-shrink:0}.toast-close:hover{color:var(--danger)}.toast-progress{opacity:.3;background-color:currentColor;width:100%;height:2px;animation:4s linear forwards progress;position:absolute;bottom:0;left:0}@keyframes progress{0%{width:100%}to{width:0%}}@media (width<=1024px){.toast-container{bottom:80px;right:var(--space-lg);left:var(--space-lg);width:auto}.toast{animation:.3s cubic-bezier(.4,0,.2,1) slideInUp}}.dialog-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:2050;padding:var(--space-md);background:#0000008c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.dialog-container{background:var(--bg-surface-1);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;padding:var(--space-lg);position:relative}.dialog-header-title{font-size:var(--text-lg);margin-bottom:var(--space-sm);align-items:center;gap:var(--space-sm);color:var(--text-primary);padding-right:28px;font-weight:700;display:flex}.dialog-title-icon{align-items:center;display:flex}.dialog-body-content{color:var(--text-secondary);font-size:var(--text-base);line-height:1.5}.dialog-footer-actions{justify-content:flex-end;gap:var(--space-sm);margin-top:var(--space-lg);display:flex}.dialog-close-btn{top:var(--space-md);right:var(--space-md);color:var(--text-secondary);opacity:.6;cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition);background:0 0;border:none;justify-content:center;align-items:center;padding:6px;display:flex;position:absolute}.dialog-close-btn:hover{background:var(--bg-surface-2);color:var(--text-primary);opacity:1}.animate-fade-in{animation:.15s fadeIn}.animate-fade-up{animation:.2s fadeUp}.confirm-dialog-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:2050;padding:var(--space-md);background:#0000008c;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.confirm-dialog{background:var(--bg-surface-1);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:440px;padding:var(--space-lg);animation:.2s fadeUp;position:relative}.confirm-dialog h2{font-size:var(--text-lg);margin-bottom:var(--space-sm);align-items:center;gap:var(--space-sm);color:var(--text-primary);font-weight:700;display:flex}.confirm-dialog p{color:var(--text-secondary);font-size:var(--text-base);line-height:1.5}.confirm-dialog__impact{border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);font-size:var(--text-sm);margin:var(--space-md) 0;gap:var(--space-sm);font-weight:500;display:flex}.confirm-dialog__impact--info{color:var(--blue-400);background:#2563eb1f;border:1px solid #2563eb4d}.confirm-dialog__impact--warning{color:var(--warning);background:#d977061f;border:1px solid #d977064d}.confirm-dialog__impact--danger{color:var(--danger);background:#dc26261f;border:1px solid #dc26264d}.confirm-dialog__keyword-label{margin-top:var(--space-lg);font-size:var(--text-sm);color:var(--text-secondary);display:block}.confirm-dialog__keyword-value{color:var(--text-primary);margin-top:var(--space-xs);font-weight:700;font-family:var(--font-mono);display:block}.confirm-dialog__keyword-input{margin-top:var(--space-sm);font-family:var(--font-mono);letter-spacing:.05em;width:100%;padding:var(--space-sm) var(--space-md);background:var(--bg-surface-3);border:1px solid var(--border-input);border-radius:var(--radius-sm);color:var(--text-primary)}.confirm-dialog__keyword-input:focus{border-color:var(--border-focus);outline:none}.confirm-dialog__error{margin-top:var(--space-md);padding:var(--space-md);border:1px solid var(--danger);border-radius:var(--radius-sm);color:var(--danger);font-size:var(--text-sm);gap:var(--space-sm);background:#dc26261a;display:flex}.confirm-dialog__actions{justify-content:flex-end;gap:var(--space-sm);margin-top:var(--space-lg);display:flex}.confirm-dialog__actions button,.btn-cancel,.btn-confirm{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);font-weight:600;font-size:var(--text-sm);cursor:pointer;transition:var(--transition)}.btn-cancel{border:1px solid var(--border-default);color:var(--text-secondary);background:0 0}.btn-cancel:hover{background:var(--bg-surface-2)}.btn-confirm{color:#fff;border:none}.btn-confirm--info{background:var(--blue-500)}.btn-confirm--info:hover{background:var(--blue-400)}.btn-confirm--warning{background:var(--warning)}.btn-confirm--warning:hover{background:#b45309}.btn-confirm--danger{background:var(--danger)}.btn-confirm--danger:hover{background:#b91c1c}.btn-confirm:disabled{opacity:.5;cursor:not-allowed}.btn--loading{position:relative;color:#0000!important}.btn--loading:after{content:"";border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;margin:-8px 0 0 -8px;animation:.6s linear infinite spin;position:absolute;top:50%;left:50%}.login-page{background-color:var(--bg-base);min-height:100vh;padding:var(--space-md);background-image:radial-gradient(circle at 10% 20%,#2563eb0d 0%,#0000 40%),radial-gradient(circle at 90% 80%,#2563eb0d 0%,#0000 40%);justify-content:center;align-items:center;display:flex}.login-content{gap:var(--space-xl);flex-direction:column;width:100%;max-width:420px;animation:.4s ease-out fadeUp;display:flex}.login-brand{justify-content:center;display:flex}.login-card{background-color:var(--bg-surface-1);border-radius:var(--radius-xl);border:1px solid var(--border-default);box-shadow:var(--shadow-lg);padding:40px}.login-header{text-align:center;margin-bottom:var(--space-xl)}.login-title{font-size:var(--text-xl);color:var(--text-primary);margin-bottom:8px;font-weight:700}.login-subtitle{font-size:var(--text-sm);color:var(--text-secondary)}.login-form{flex-direction:column;gap:20px;display:flex}.form-group{flex-direction:column;gap:8px;display:flex}.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{color:var(--text-muted);z-index:10;pointer-events:none;position:absolute;left:16px}.input-wrapper input{background-color:var(--bg-surface-3);border:1.5px solid var(--border-input);border-radius:var(--radius-md);width:100%;height:48px;color:var(--text-primary);font-size:var(--text-base);transition:var(--transition);padding:0 16px 0 44px!important}.input-wrapper input:focus{border-color:var(--border-focus);background-color:var(--bg-surface-1);outline:none;box-shadow:0 0 0 3px #2563eb2e}.login-error{background-color:var(--danger-light);border:1px solid var(--danger);border-radius:var(--radius-md);color:var(--danger);font-size:var(--text-xs);align-items:center;gap:10px;padding:12px;font-weight:600;display:flex}[data-theme=dark] .login-error{background-color:#dc26261a}.login-submit-btn{width:100%;height:48px;margin-top:8px}.login-footer{text-align:center;font-size:var(--text-xs);color:var(--text-muted);font-weight:500}@media (width<=480px){.login-card{padding:var(--space-xl) 24px}}.layout-container{background-color:var(--bg-base);min-height:100vh;display:flex}.sidebar{background-color:var(--bg-surface-1);border-right:1px solid var(--border-default);z-index:100;flex-direction:column;width:240px;height:100vh;transition:width .2s cubic-bezier(.4,0,.2,1);display:flex;position:sticky;top:0}.sidebar-overlay{display:none}.sidebar.collapsed{width:80px}.sidebar-header{border-bottom:1px solid var(--border-default);flex-shrink:0;align-items:center;height:72px;min-height:72px;padding:16px;display:flex}.sidebar.collapsed .sidebar-header{justify-content:center;padding:0}.collapse-toggle-sidebar{width:32px;height:32px;color:var(--text-secondary);background-color:var(--bg-surface-2);border:1px solid var(--border-default);transition:var(--transition);cursor:pointer;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.collapse-toggle-sidebar:hover{border-color:var(--blue-400);color:var(--blue-500)}.sidebar.collapsed .collapse-toggle-sidebar{z-index:101;background-color:var(--bg-surface-1);box-shadow:var(--shadow-sm);position:absolute;top:14px;right:-14px}.sidebar-nav{flex-direction:column;flex:1;margin-top:12px;padding:0 12px;display:flex}.nav-group{flex-direction:column;gap:4px;display:flex}.nav-separator{background-color:var(--border-default);height:1px;margin:16px 12px}.nav-item{border-radius:var(--radius-md);color:var(--text-secondary);font-weight:500;font-size:var(--text-sm);transition:var(--transition);align-items:center;gap:12px;padding:12px 16px;text-decoration:none;display:flex;position:relative}.nav-item:hover{color:var(--text-primary);background-color:#2563eb0f}.nav-item.active{color:var(--blue-300);background-color:#2563eb1f}.nav-item.active:before{content:"";background-color:var(--blue-400);border-radius:0 4px 4px 0;width:3px;height:70%;position:absolute;top:15%;left:0}.nav-item-wrapper{flex-direction:column;display:flex}.has-submenu{cursor:pointer;-webkit-user-select:none;user-select:none}.has-submenu.active-parent{color:var(--blue-300)}.submenu-chevron{color:inherit;align-items:center;margin-left:auto;display:flex}.submenu-container{flex-direction:column;transition:max-height .3s ease-in-out;display:flex;overflow:hidden}.submenu-item{padding-top:10px;padding-bottom:10px;padding-left:48px;font-size:13px}.sidebar.collapsed .submenu-item{padding-left:12px}.sidebar.collapsed .nav-item{justify-content:center;padding:12px}.sidebar.collapsed .nav-item span{display:none}.sidebar-footer{border-top:1px solid var(--border-default);padding:12px}.footer-actions{justify-content:space-between;align-items:center;gap:8px;display:flex}.user-profile-sidebar{flex:1;align-items:center;gap:12px;min-width:0;display:flex}.sidebar.collapsed .user-profile-sidebar{justify-content:center}.logout-btn-v2{border-radius:var(--radius-md);width:36px;height:36px;color:var(--danger);transition:var(--transition);flex-shrink:0;justify-content:center;align-items:center;display:flex}.logout-btn-v2:hover{background-color:#dc26261a}.sidebar.collapsed .footer-actions{flex-direction:column;gap:16px}.sidebar.collapsed .logout-btn-v2{width:100%}.main-content{flex-direction:column;flex:1;min-width:0;display:flex}.top-header{background-color:var(--bg-surface-1);border-bottom:1px solid var(--border-default);height:56px;padding:0 var(--space-xl);z-index:90;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.header-left{align-items:center;gap:var(--space-md);flex:1;display:flex}.mobile-menu-btn{color:var(--text-primary);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;margin-left:-8px;padding:8px;display:none}.mobile-menu-btn:hover{background-color:var(--bg-surface-2)}.header-page-info{flex-direction:column;display:flex}.header-title{color:var(--text-primary);margin:0;font-size:18px;font-weight:700;line-height:1}.header-right{align-items:center;gap:var(--space-sm);display:flex}.header-action-btn{width:36px;height:36px;color:var(--text-secondary);transition:var(--transition);border-radius:8px;justify-content:center;align-items:center;display:flex;position:relative}.header-action-btn:hover{background-color:var(--bg-surface-2);color:var(--blue-500)}.notification-dot{background-color:var(--danger);border:2px solid var(--bg-surface-1);border-radius:50%;width:8px;height:8px;position:absolute;top:8px;right:8px}.theme-toggle{width:36px;height:36px;color:var(--text-secondary);background-color:var(--bg-surface-2);border:1px solid var(--border-default);transition:var(--transition);border-radius:8px;justify-content:center;align-items:center;display:flex}.theme-toggle:hover{border-color:var(--blue-400);color:var(--blue-500)}.avatar{background:linear-gradient(135deg, var(--blue-500), var(--blue-300));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:600;display:flex}.user-details{flex-direction:column;min-width:0;display:flex}.user-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;line-height:1.2;overflow:hidden}.user-role{color:var(--text-secondary);font-size:11px}.page-body{padding:var(--space-lg);flex:1;width:100%;max-width:1440px;margin:0 auto;animation:.3s ease-out fadeUp}@media (width<=1024px){.sidebar:not(.mobile-open){width:80px}.sidebar:not(.mobile-open) .nav-item span,.sidebar:not(.mobile-open) .logout-btn-v2 span,.sidebar:not(.mobile-open) .sidebar-header span,.sidebar:not(.mobile-open) .sidebar-header .logo-text-wrapper{display:none}.sidebar{z-index:1000;background-color:var(--bg-surface-1);width:280px;box-shadow:var(--shadow-xl);transition:transform .3s cubic-bezier(.16,1,.3,1);display:flex;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.sidebar-overlay{z-index:999;-webkit-backdrop-filter:blur(2px);opacity:0;pointer-events:none;background-color:#00000080;transition:opacity .3s ease-out;display:block;position:fixed;inset:0}.sidebar-overlay.open{opacity:1;pointer-events:auto}.sidebar.mobile-open{transform:translate(0)}.sidebar.mobile-open .user-details{display:flex}.top-header{padding:0 16px}.header-left .user-details{display:none}.page-body{padding:16px}.mobile-menu-btn{justify-content:center;align-items:center;display:flex}}.mobile-drawer-menu{gap:var(--space-sm);flex-direction:column;display:flex}.mobile-drawer-item{align-items:center;gap:var(--space-md);padding:var(--space-md);background-color:var(--bg-surface-2);border-radius:var(--radius-lg);color:var(--text-primary);border:1px solid var(--border-default);transition:var(--transition);text-decoration:none;display:flex}.mobile-drawer-item:hover,.mobile-drawer-item.active{border-color:var(--blue-500);background-color:#2563eb0d}.mobile-drawer-icon{border-radius:var(--radius-md);background-color:var(--bg-surface-1);width:48px;height:48px;color:var(--blue-400);box-shadow:var(--shadow-sm);flex-shrink:0;justify-content:center;align-items:center;display:flex}.mobile-drawer-item.active .mobile-drawer-icon{background-color:var(--blue-500);color:#fff}.mobile-drawer-info{flex-direction:column;gap:4px;display:flex}.mobile-drawer-title{font-weight:600;font-size:var(--text-md)}.mobile-drawer-desc{font-size:var(--text-sm);color:var(--text-muted)}@keyframes slideInLeft{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}.sidebar.collapsed .logo-img-expanded{display:none!important}.sidebar.collapsed .logo-img-collapsed{display:block!important}.sidebar.collapsed .logo-icon-wrapper{width:36px!important;height:36px!important}.sidebar.collapsed .sidebar-header{justify-content:center!important;height:64px!important;min-height:64px!important;padding:0!important}@media (width<=1024px){.sidebar:not(.mobile-open) .logo-img-expanded{display:none!important}.sidebar:not(.mobile-open) .logo-img-collapsed{display:block!important}.sidebar:not(.mobile-open) .logo-icon-wrapper{width:36px!important;height:36px!important}.sidebar:not(.mobile-open) .sidebar-header{justify-content:center!important;height:64px!important;min-height:64px!important;padding:0!important}}.card-v2{background-color:var(--bg-surface-1);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:12px var(--space-md);transition:transform .15s,box-shadow .15s}.stats-card-v2{border-top:2px solid var(--blue-500);align-items:center;gap:var(--space-md);flex-direction:row;display:flex}.stats-card-v2:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stats-card-header-v2{flex-shrink:0;align-items:center;display:flex}.stats-card-icon-v2{border-radius:var(--radius-md);justify-content:center;align-items:center;width:40px;height:40px;display:flex;position:relative;overflow:hidden}.icon-bg-v2{opacity:.1;position:absolute;inset:0}.icon-inner-v2{z-index:1;justify-content:center;align-items:center;display:flex;position:relative}.stats-card-body-v2{flex-direction:column;flex:1;justify-content:center;display:flex}.stats-value-v2{font-size:var(--text-xl);color:var(--text-primary);letter-spacing:-.3px;margin:0;font-weight:700;line-height:1.25}.stats-title-v2{font-size:var(--text-xs);color:var(--text-secondary);margin:0;font-weight:500}.stats-subtitle-v2{color:var(--text-muted);margin-top:1px;font-size:10px}.data-table-container{width:100%}.table-wrapper{background-color:var(--bg-surface-1);border-radius:var(--radius-lg);border:1px solid var(--border-default);box-shadow:var(--shadow-sm);margin-bottom:var(--space-xs);overflow:auto hidden}.data-table{border-collapse:collapse;text-align:left;width:100%}.data-table th{padding:var(--space-sm) var(--space-md);background-color:var(--bg-surface-2);color:var(--text-secondary);font-weight:600;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-default)}.data-table td{padding:var(--space-sm) var(--space-md);color:var(--text-primary);font-size:var(--text-sm);border-bottom:1px solid var(--border-default);transition:var(--transition)}.data-table tr:last-child td{border-bottom:none}.data-table tr.clickable{cursor:pointer}.data-table tr.clickable:hover td{background-color:var(--bg-surface-2)}.data-table tr.selected td{background-color:#2563eb0d}.actions-column{white-space:nowrap;width:1%;padding-left:var(--space-md);padding-right:var(--space-md)}.selection-column{text-align:center;width:40px;padding:0 var(--space-sm)}.checkbox-input{cursor:pointer;width:18px;height:18px;accent-color:var(--blue-500)}.actions-cell{flex-flow:row;justify-content:flex-start;align-items:center;gap:0;display:flex}.icon-btn{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--text-secondary);transition:var(--transition);justify-content:center;align-items:center;display:flex}.icon-btn-primary{color:var(--blue-500)}.icon-btn-primary:hover{background-color:#2563eb1a}.icon-btn-danger{color:var(--danger)}.icon-btn-danger:hover{background-color:#dc26261a}.icon-btn-success{color:var(--success)}.icon-btn-success:hover{background-color:#0596691a}.icon-btn-warning{color:var(--warning)}.icon-btn-warning:hover{background-color:#d977061a}.icon-btn:disabled{opacity:.4;cursor:not-allowed}.card-list{gap:var(--space-md);flex-direction:column;display:none}.mobile-card-wrapper{animation:.25s ease-out forwards fadeUp}.empty-state,.loading-state{padding:var(--space-xl);text-align:center;color:var(--text-muted);font-style:italic;font-size:var(--text-sm)}@media (width<=1024px){.table-wrapper{display:none}.card-list{display:flex}}.badge{border-radius:var(--radius-full);font-size:var(--text-xs);letter-spacing:.02em;text-transform:uppercase;white-space:nowrap;align-items:center;gap:5px;padding:3px 10px;font-weight:600;display:inline-flex}.pulse-dot{background-color:currentColor;border-radius:50%;width:6px;height:6px;animation:2s infinite pulse}.badge-active,.badge-em_dia,.badge-online{color:#065f46;background:#d1fae5}.badge-late,.badge-atrasado,.badge-overdue{color:#92400e;background:#fef3c7}.badge-blocked,.badge-bloqueado,.badge-offline{color:#991b1b;background:#fee2e2}.badge-pending{color:#1e40af;background:#dbeafe}.badge-paid,.badge-success{color:#065f46;background:#d1fae5}.badge-cancelled,.badge-inactive{color:#6b7280;background:#f3f4f6}[data-theme=dark] .badge-active,[data-theme=dark] .badge-em_dia,[data-theme=dark] .badge-online{color:#34d399;background:#10b98126}[data-theme=dark] .badge-late,[data-theme=dark] .badge-atrasado,[data-theme=dark] .badge-overdue{color:#fcd34d;background:#d9770626}[data-theme=dark] .badge-blocked,[data-theme=dark] .badge-bloqueado,[data-theme=dark] .badge-offline{color:#fca5a5;background:#dc262626}[data-theme=dark] .badge-pending{color:#93c5fd;background:#2563eb26}[data-theme=dark] .badge-paid,[data-theme=dark] .badge-success{color:#34d399;background:#10b98126}[data-theme=dark] .badge-cancelled,[data-theme=dark] .badge-inactive{color:#9ca3af;background:#6b728026}.mobile-card{background-color:var(--bg-surface-1);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);flex-direction:column;gap:8px;padding:10px 12px;transition:transform .15s,box-shadow .15s;display:flex}.mobile-card-header{align-items:center;gap:10px;display:flex}.mobile-card-icon{border-radius:var(--radius-md);width:32px;height:32px;color:var(--blue-300);background-color:#2563eb1a;flex-shrink:0;justify-content:center;align-items:center;display:flex}.mobile-card-titles{flex-direction:column;min-width:0;display:flex}.mobile-card-title{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:14px;font-weight:700;overflow:hidden}.mobile-card-subtitle{color:var(--text-secondary);font-size:11px}.mobile-card-body{justify-content:space-between;align-items:center;display:flex}.mobile-card-extra{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-secondary)}.mobile-card-footer{border-top:1px solid var(--border-default);justify-content:space-between;align-items:center;padding-top:8px;display:flex}.mobile-card-drawer-btn{align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);color:var(--blue-300);font-size:var(--text-sm);cursor:pointer;background-color:#2563eb1a;border:1px solid #2563eb40;font-weight:500;transition:all .15s;display:flex}.mobile-card-drawer-btn:active{background-color:#2563eb33;transform:scale(.97)}.drawer-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:2000;opacity:0;pointer-events:none;background-color:#0b112080;transition:opacity .25s;position:fixed;inset:0}.drawer-overlay.open{opacity:1;pointer-events:auto}.drawer-content{background-color:var(--bg-surface-1);z-index:2001;box-shadow:var(--shadow-lg);flex-direction:column;transition:transform .25s cubic-bezier(.4,0,.2,1);display:flex;position:fixed}.drawer-handle{background-color:var(--border-default);border-radius:var(--radius-full);width:40px;height:4px;margin:var(--space-sm) auto var(--space-xs);flex-shrink:0;display:none}@media (width>=641px){.drawer-content{border-left:1px solid var(--border-default);width:480px;top:0;bottom:0;right:0;transform:translate(100%)}.drawer-content--large{width:720px;max-width:90vw}.drawer-content.open{transform:translate(0)}}@media (width<=1024px){.drawer-content{border-radius:var(--radius-xl) var(--radius-xl) 0 0;border-top:1px solid var(--border-default);height:92vh;padding-bottom:env(safe-area-inset-bottom);bottom:0;left:0;right:0;transform:translateY(100%)}.drawer-content.open{transform:translateY(0)}.drawer-handle{display:block}}.drawer-header{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-default);justify-content:space-between;align-items:center;display:flex}.drawer-title{font-size:var(--text-lg);color:var(--text-primary);margin:0;font-weight:700}.drawer-close{width:36px;height:36px;color:var(--text-secondary);transition:var(--transition);border-radius:50%;justify-content:center;align-items:center;display:flex}.drawer-close:hover{background-color:var(--bg-surface-2);color:var(--danger)}.drawer-body{padding:var(--space-lg);flex:1;overflow-y:auto}.drawer-content .input,.drawer-content input,.drawer-content select{background-color:var(--bg-surface-3);border:1.5px solid var(--border-input)}.searchable-selector-trigger{background-color:var(--bg-surface-3);border:1.5px solid var(--border-input);border-radius:var(--radius-md);cursor:pointer;width:100%;height:44px;transition:var(--transition);justify-content:space-between;align-items:center;padding:0 14px;display:flex}.searchable-selector-trigger:focus,.searchable-selector-trigger:hover:not(.disabled){border-color:var(--border-focus)}.searchable-selector-trigger.is-open{border-color:var(--border-focus);background-color:var(--bg-surface-1);box-shadow:0 0 0 3px #2563eb2e}.searchable-selector-trigger.disabled{opacity:.6;cursor:not-allowed}.selected-text{color:var(--text-primary);font-size:var(--text-sm);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.placeholder-text{color:var(--text-muted);font-size:var(--text-sm)}.trigger-icon{color:var(--text-secondary);flex-shrink:0}.selector-drawer-content{flex-direction:column;height:100%;max-height:calc(100vh - 100px);display:flex}.selector-search-wrapper{padding:0 0 var(--space-md) 0;margin-bottom:var(--space-sm)}.selector-search-wrapper .search-box{width:100%;max-width:none;position:relative}.selector-search-wrapper .search-icon{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.selector-search-wrapper .search-box input{background-color:var(--bg-surface-3);border:1.5px solid var(--border-input);border-radius:var(--radius-md);width:100%;height:40px;color:var(--text-primary);font-size:var(--text-sm);transition:var(--transition);padding:0 12px 0 40px}.selector-search-wrapper .search-box input:focus{border-color:var(--border-focus);outline:none;box-shadow:0 0 0 3px #2563eb2e}.selector-options-list{padding:var(--space-sm);flex-direction:column;flex:1;gap:2px;display:flex;overflow-y:auto}.selector-option{border-radius:var(--radius-md);cursor:pointer;color:var(--text-secondary);font-size:var(--text-sm);padding:12px 16px;transition:all .15s}.selector-option:hover{color:var(--text-primary);background-color:#2563eb0d}.selector-option.selected{color:var(--blue-500);background-color:#2563eb1a;font-weight:500}.selector-empty{padding:var(--space-lg);text-align:center;color:var(--text-muted);font-style:italic;font-size:var(--text-sm)}.tenant-form{flex-direction:column;display:flex}.form-section:first-child{margin-top:-12px}.section-title{margin-bottom:var(--space-sm);color:var(--text-primary);border-bottom:1px solid var(--border-default);align-items:center;gap:8px;padding-bottom:6px;font-size:14px;font-weight:700;display:flex}.section-title svg{color:var(--blue-500)}.form-grid{gap:var(--space-sm);grid-template-columns:1fr;display:grid}.form-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.025em;white-space:nowrap;text-overflow:ellipsis;font-size:11px;font-weight:600;display:block;overflow:hidden}.form-group input{border:1.5px solid var(--border-input);background-color:var(--bg-surface-2);width:100%;color:var(--text-primary);transition:var(--transition);border-radius:8px;padding:8px 12px;font-size:14px}.drawer-footer{justify-content:flex-end;align-items:center;gap:var(--space-sm);padding-top:12px;display:flex}.provisioning-progress{text-align:center;padding:40px 24px}.steps-container{gap:var(--space-lg);flex-direction:column;max-width:320px;margin:0 auto;display:flex}.step-item{align-items:center;gap:var(--space-md);color:var(--text-muted);font-size:15px;font-weight:500;display:flex}.step-item.active{color:var(--blue-500);font-weight:700}.step-item.completed{color:var(--success)}.step-item svg{width:24px;height:24px}.spinning{animation:1s linear infinite spin}@media (width<=1024px){.form-grid{grid-template-columns:1fr}}.empty-state-container{text-align:center;padding:var(--space-2xl) var(--space-lg);background-color:var(--bg-surface-1);border-radius:var(--radius-lg);flex-direction:column;justify-content:center;align-items:center;width:100%;display:flex}.empty-state-icon{background-color:var(--bg-surface-2);width:80px;height:80px;color:var(--blue-400);margin-bottom:var(--space-lg);box-shadow:var(--shadow-sm);border-radius:50%;justify-content:center;align-items:center;display:flex}.empty-state-icon svg{width:40px;height:40px}.empty-state-title{font-size:var(--text-lg);color:var(--text-primary);margin-bottom:var(--space-sm);font-weight:700}.empty-state-description{font-size:var(--text-sm);color:var(--text-muted);max-width:400px;margin-bottom:var(--space-xl);line-height:1.6}.empty-state-action{justify-content:center;display:flex}.admin-stats{gap:var(--space-md);display:flex}.admin-stat-card{background-color:var(--bg-surface-2);border:1px solid var(--border-default);border-radius:var(--radius-md);align-items:center;gap:var(--space-sm);min-width:140px;padding:12px 20px;display:flex}.stat-info{flex-direction:column;display:flex}.stat-label{font-size:var(--text-xs);color:var(--text-secondary);font-weight:500}.stat-value{font-size:var(--text-lg);color:var(--text-primary);font-weight:700}.tenant-name-cell{flex-direction:column;display:flex}@media (width<=1024px){.admin-stats{width:100%;margin-top:var(--space-md)}.admin-stat-card{flex:1}}.map-dashboard-container{border-radius:var(--radius-xl,16px);box-shadow:var(--shadow-md,0 4px 6px #0000001a);flex-direction:column;display:flex;position:relative;overflow:hidden}.map-placeholder{background:var(--bg-glass,#ffffff0d);border-radius:var(--radius-xl,16px);text-align:center;flex-direction:column;justify-content:center;align-items:center;height:100%;min-height:400px;padding:2rem;display:flex}.map-popup-dark .mapboxgl-popup-content{background:var(--bg-surface,#1e1e1e);color:var(--text-primary,#fff);border:1px solid var(--border-default,#333);border-radius:8px;padding:12px;box-shadow:0 10px 25px #00000080}.map-popup-dark .mapboxgl-popup-tip{border-top-color:var(--bg-surface,#1e1e1e)}.custom-pin{transition:transform .2s}.custom-pin:hover{transform:scale(1.2)translateY(-5px)}.health-card{background:var(--bg-surface-2);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:var(--space-md);margin-bottom:var(--space-lg)}.health-header{margin-bottom:var(--space-md);border-bottom:1px solid var(--border-default);padding-bottom:8px}.router-model{font-size:var(--text-sm);color:var(--text-secondary);align-items:center;gap:8px;font-weight:600;display:flex}.badge-outline{font-size:var(--text-xs);border:1px solid var(--border-default);border-radius:var(--radius-sm);font-family:var(--font-mono);padding:2px 6px}.health-stat{flex-direction:column;gap:6px;display:flex}.stat-label{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:6px;display:flex}.stat-progress-wrapper{background:var(--bg-surface-3);border-radius:3px;height:6px;overflow:hidden}.progress-bar{height:100%;transition:width .5s}.bg-success{background-color:var(--success)}.bg-warning{background-color:var(--warning)}.bg-danger{background-color:var(--danger)}.stat-info{justify-content:space-between;align-items:baseline;display:flex}.stat-value{font-size:var(--text-lg);font-family:var(--font-mono)}.stat-sub{font-size:var(--text-xs);color:var(--text-muted)}.stat-network{gap:var(--space-md);align-items:center;margin:4px 0;display:flex}.network-item{font-size:var(--text-base);align-items:center;gap:4px;font-weight:600;display:flex}.text-success{color:var(--success)}.uptime-value{font-family:var(--font-mono);font-size:var(--text-base);font-weight:600}.arch-name{margin-top:auto}.error-card{padding:var(--space-xl);text-align:center;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;display:flex}@media (width<=480px){.health-grid{grid-template-columns:1fr}}.dashboard-container{gap:var(--space-xl);flex-direction:column;display:flex}.stats-grid{gap:var(--space-lg);grid-template-columns:repeat(4,1fr);display:grid}.dashboard-content-grid{gap:var(--space-lg);grid-template-columns:3fr 1fr;width:100%;min-height:600px;display:grid}.dashboard-card{background-color:var(--bg-surface-1);border-radius:var(--radius-lg);border:1px solid var(--border-default);box-shadow:var(--shadow-sm);flex-direction:column;transition:transform .15s,box-shadow .15s;display:flex;overflow:hidden}.dashboard-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.card--glass{background-color:color-mix(in srgb, var(--bg-surface-1) 85%, transparent);-webkit-backdrop-filter:blur(8px)}.card-header{padding:var(--space-md) 24px;border-bottom:1px solid var(--border-default);justify-content:space-between;align-items:center;display:flex}.card-title{font-size:var(--text-lg);color:var(--text-primary);margin:0;font-weight:700}.chart-placeholder{background-color:var(--bg-surface-2);border-radius:var(--radius-lg);border:1px dashed var(--border-default);flex:1;justify-content:center;align-items:center;min-height:300px;margin:24px;display:flex}.placeholder-content{align-items:center;gap:var(--space-sm);text-align:center;flex-direction:column;display:flex}.activity-list{flex-direction:column;padding:8px 0;display:flex}.activity-item{gap:var(--space-md);padding:var(--space-md) 24px;border-bottom:1px solid var(--border-default);transition:var(--transition);display:flex}.activity-item:last-child{border-bottom:none}.activity-item:hover{background-color:var(--bg-surface-2)}.activity-icon-v2{border-radius:var(--radius-md);width:36px;height:36px;color:var(--blue-300);background-color:#2563eb1a;flex-shrink:0;justify-content:center;align-items:center;display:flex}.activity-details{flex-direction:column;gap:2px;min-width:0;display:flex}.activity-title{color:var(--text-primary);font-size:14px;font-weight:700}.activity-desc{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;overflow:hidden}.activity-time{color:var(--text-muted);margin-top:4px;font-size:11px}.empty-feed{text-align:center;color:var(--text-muted);padding:40px 24px;font-size:14px;font-style:italic}.view-all-btn{padding:var(--space-md);background-color:var(--bg-surface-2);color:var(--blue-400);text-align:center;border-top:1px solid var(--border-default);transition:var(--transition);font-size:13px;font-weight:600}.view-all-btn:hover{background-color:#2563eb0d}.activity-item-skeleton{gap:var(--space-md);padding:var(--space-md) 24px;display:flex}.skeleton--circle{border-radius:50%}.skeleton--xs{height:10px}@media (width<=1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=1024px){.dashboard-content-grid{grid-template-columns:1fr}.stats-grid{gap:var(--space-sm);grid-template-columns:repeat(2,1fr)}.dashboard-container{gap:var(--space-lg)}}.form-grid{grid-template-columns:1fr 1fr;gap:20px;display:grid}.form-section{border-bottom:1px solid var(--border-default);color:var(--blue-500);font-weight:700;font-family:var(--font-body);font-size:var(--text-lg);grid-column:span 2;margin-top:12px;padding-bottom:8px}.form-actions{justify-content:flex-end;gap:var(--space-sm);margin-top:var(--space-lg);grid-column:span 2;display:flex}.full-width{grid-column:span 2}@media (width<=1024px){.form-grid{grid-template-columns:1fr}.form-section,.full-width,.form-actions{grid-column:span 1}.form-actions{flex-direction:column}.form-actions button{width:100%}}.bulk-actions-bar{background-color:var(--blue-600);color:#fff;border-radius:var(--radius-lg);padding:var(--space-sm) var(--space-md);margin-bottom:var(--space-sm);box-shadow:var(--shadow-blue);z-index:10;animation:.2s ease-out slideInUp}[data-theme=dark] .bulk-actions-bar{background-color:var(--blue-500)}.bulk-actions-content{align-items:center;gap:var(--space-md);height:32px;display:flex}.selection-info{align-items:center;gap:var(--space-sm);display:flex}.clear-btn{color:#ffffffb3;justify-content:center;align-items:center;transition:color .2s;display:flex}.clear-btn:hover{color:#fff}.count-badge{color:var(--blue-600);font-size:var(--text-xs);padding:2px var(--space-sm);border-radius:var(--radius-full);background-color:#fff;font-weight:700}.selection-text{font-size:var(--text-sm);font-weight:500}.bulk-actions-bar .divider{background-color:#fff3;width:1px;height:20px}.actions-group{align-items:center;gap:var(--space-sm);flex:1;display:flex}.bulk-action-btn{align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--text-xs);color:#fff;background-color:#ffffff1a;font-weight:600;transition:all .2s;display:flex}.bulk-action-btn:hover{background-color:#fff3}.bulk-action-btn svg{width:14px;height:14px}.bulk-action-btn.variant-danger:hover{background-color:var(--danger)}.bulk-action-btn.variant-success:hover{background-color:var(--success)}@media (width<=1024px){.bulk-actions-bar{margin-bottom:0;position:fixed;bottom:80px;left:16px;right:16px}.selection-text{display:none}}.pagination-container{justify-content:space-between;align-items:center;width:100%;padding:4px 0;display:flex}.pagination-btn{border-radius:var(--radius-sm);background-color:var(--bg-surface-1);border:1px solid var(--border-default);width:36px;height:36px;color:var(--text-primary);font-size:var(--text-sm);transition:var(--transition);cursor:pointer;justify-content:center;align-items:center;font-weight:500;display:flex}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-btn:not(:disabled):hover{border-color:var(--blue-400);color:var(--blue-500);background-color:var(--bg-surface-2)}.pagination-pages-list{align-items:center;gap:6px;display:flex}.pagination-page-btn{border-radius:var(--radius-sm);background-color:var(--bg-surface-1);border:1px solid var(--border-default);width:36px;height:36px;color:var(--text-primary);font-size:var(--text-sm);transition:var(--transition);cursor:pointer;justify-content:center;align-items:center;font-weight:600;display:flex}.pagination-page-btn:hover:not(.active):not(:disabled){border-color:var(--blue-400);color:var(--blue-500);background-color:var(--bg-surface-2)}.pagination-page-btn.active{background-color:var(--blue-500);border-color:var(--blue-500);color:#fff;cursor:default}.pagination-dots{width:36px;height:36px;color:var(--text-muted);font-size:var(--text-sm);justify-content:center;align-items:center;font-weight:600;display:flex}@media (width<=1024px){.pagination-container{gap:var(--space-md);flex-direction:column;align-items:stretch}.pagination-info{text-align:center}.pagination-controls{justify-content:center}}.page-header{justify-content:space-between;align-items:center;display:flex}.page-title{font-size:var(--text-2xl);color:var(--text-primary);margin:0;font-weight:700}.page-subtitle{color:var(--text-secondary);font-size:var(--text-sm);margin:4px 0 0}.search-box{flex:1;max-width:400px;position:relative}.search-icon{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.search-box input{background-color:var(--bg-surface-1);border:1.5px solid var(--border-input);border-radius:var(--radius-md);width:100%;height:40px;color:var(--text-primary);font-size:var(--text-sm);transition:var(--transition);padding:0 12px 0 40px}.search-box input:focus{border-color:var(--border-focus);outline:none;box-shadow:0 0 0 3px #2563eb2e}.pagination{padding:var(--space-md) 0;justify-content:space-between;align-items:center;display:flex}.pagination-info{font-size:var(--text-xs);color:var(--text-secondary);font-weight:500}.pagination-controls{align-items:center;gap:var(--space-sm);display:flex}.page-btn{border-radius:var(--radius-sm);background-color:var(--bg-surface-1);border:1px solid var(--border-default);width:36px;height:36px;color:var(--text-primary);transition:var(--transition);justify-content:center;align-items:center;display:flex}.page-btn:disabled{opacity:.5;cursor:not-allowed}.page-btn:not(:disabled):hover{border-color:var(--blue-400);color:var(--blue-500)}.page-indicator{font-size:var(--text-sm);font-weight:600}.warning-drawer{text-align:center;align-items:center;gap:var(--space-md);padding:var(--space-lg) 0;flex-direction:column;display:flex}.warning-icon{color:var(--danger);margin-bottom:8px}.warning-text{font-size:var(--text-lg);margin:0;font-weight:700}.warning-subtext{color:var(--text-secondary);font-size:var(--text-sm)}.drawer-actions{gap:var(--space-sm);width:100%;margin-top:var(--space-md);flex-direction:column;display:flex}@media (width<=1024px){.page-header{align-items:stretch;gap:var(--space-md);flex-direction:column}.pagination{gap:var(--space-md);flex-direction:column}}.plan-form{flex-direction:column;gap:20px;display:flex}.section-divider{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-default);margin-top:10px;padding-bottom:8px;font-weight:700}.form-grid-2{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}.form-checkbox{background-color:var(--bg-surface-2);border-radius:var(--radius-md);border:1px solid var(--border-default);align-items:center;gap:10px;padding:12px;display:flex}.form-checkbox input{cursor:pointer;width:18px;height:18px}.form-checkbox label{font-size:var(--text-sm);color:var(--text-primary);cursor:pointer;font-weight:500}@media (width<=1024px){.form-actions{flex-direction:column}.form-actions button{width:100%}}.font-semibold{font-weight:600}.error-alert{background-color:var(--danger-light);border:1px solid var(--danger);border-radius:var(--radius-md);width:100%;color:var(--danger);font-size:var(--text-xs);text-align:left;padding:12px}[data-theme=dark] .error-alert{background-color:#dc26261a}.router-form{flex-direction:column;gap:20px;display:flex}.router-health-section{background-color:var(--bg-surface-2);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-md);margin-bottom:8px}.health-loading,.health-error{align-items:center;gap:var(--space-sm);font-size:var(--text-sm);color:var(--text-secondary);display:flex}.health-grid{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}.health-item{flex-direction:column;gap:4px;display:flex}.health-label{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.02em;align-items:center;gap:6px;font-weight:500;display:flex}.health-value{font-size:var(--text-sm);color:var(--text-primary);font-weight:600;font-family:var(--font-mono)}.spin{animation:1s linear infinite spin}.form-group input{background-color:var(--bg-surface-3);border:1.5px solid var(--border-input);border-radius:var(--radius-md);width:100%;height:44px;color:var(--text-primary);font-size:var(--text-sm);transition:var(--transition);padding:0 14px}.form-group input:focus{border-color:var(--border-focus);background-color:var(--bg-surface-1);outline:none;box-shadow:0 0 0 3px #2563eb2e}@media (width<=1024px){.form-actions{flex-direction:column}.form-actions button{width:100%}}.router-name-cell{flex-direction:column;align-items:flex-start;gap:2px;display:flex}.text-blue{color:var(--blue-300)}.stats-cell{flex-direction:column;gap:4px;display:flex}.stat-item{align-items:center;gap:6px;line-height:1;display:flex}.stat-value{font-family:var(--font-mono);font-size:var(--text-xs)}.small{font-size:var(--text-xs)}.fw-bold{font-weight:700}.routers-grid{margin-top:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;display:grid}.router-monitor-card{background:var(--bg-surface-1);border:1px solid var(--border-default);border-radius:12px;flex-direction:column;gap:8px;padding:12px 14px;transition:transform .2s,box-shadow .2s;display:flex}.router-monitor-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.router-monitor-card .card-header{border-bottom:1px solid var(--border-default);justify-content:space-between;align-items:flex-start;padding-bottom:8px;display:flex}.router-monitor-card .router-info{gap:var(--space-sm);display:flex}.router-monitor-card .stat-item{gap:var(--space-sm);align-items:center;display:flex}.router-monitor-card .stat-icon{background:var(--bg-surface-2);width:32px;height:32px;color:var(--text-muted);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.router-monitor-card .stat-details{flex:1}.router-monitor-card .label{color:var(--text-muted);margin-bottom:2px;font-size:11px;display:block}.router-monitor-card .value{color:var(--text-primary);font-size:13px;font-weight:600}.router-monitor-card .progress-bar{background:var(--bg-surface-2);border-radius:3px;height:6px;margin:4px 0;overflow:hidden}.router-monitor-card .progress-fill{background:var(--blue-500);border-radius:3px;height:100%;transition:width .5s}.router-monitor-card .progress-fill.warning{background:var(--warning)}.router-monitor-card .progress-fill.danger{background:var(--danger)}.cursor-pointer{cursor:pointer}.connection-form{flex-direction:column;gap:20px;display:flex}.form-group label{font-size:var(--text-sm);color:var(--text-primary);font-weight:600}.form-group input,.form-group select{background-color:var(--bg-surface-3);border:1.5px solid var(--border-input);border-radius:var(--radius-md);width:100%;height:44px;color:var(--text-primary);font-size:var(--text-sm);transition:var(--transition);padding:0 14px}.form-group input:focus,.form-group select:focus{border-color:var(--border-focus);background-color:var(--bg-surface-1);outline:none;box-shadow:0 0 0 3px #2563eb2e}.form-group input:disabled{opacity:.5;cursor:not-allowed}.password-input-wrapper{align-items:center;width:100%;display:flex;position:relative}.password-input-wrapper input{padding-right:40px}.toggle-password{color:var(--text-muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:0;transition:color .15s;display:flex;position:absolute;right:12px}.toggle-password:hover{color:var(--text-primary)}.form-actions{justify-content:flex-end;gap:var(--space-sm);margin-top:12px;display:flex}@media (width<=1024px){.form-actions{flex-direction:column}.form-actions button{width:100%}}.connection-cell,.client-cell,.plan-cell{flex-direction:column;gap:2px;display:flex}.mono-code{background-color:var(--bg-surface-3);color:var(--blue-300);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:var(--text-xs);border:1px solid var(--border-default);width:fit-content;padding:2px 6px}.text-xs{font-size:var(--text-xs)}.view-mode-toggle{background:var(--bg-surface-2);border-radius:var(--radius-md);margin-bottom:var(--space-sm);border:1px solid var(--border-default);width:fit-content;padding:4px;display:flex}.page-container{gap:var(--space-sm);flex-direction:column;display:flex}.filter-bar{gap:var(--space-md);align-items:center;display:flex}.toggle-btn{color:var(--text-secondary);font-size:var(--text-sm);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;align-items:center;gap:8px;padding:8px 16px;font-weight:500;transition:all .2s;display:flex}.toggle-btn:hover{color:var(--text-primary)}.toggle-btn.active{background:var(--bg-surface-1);color:var(--blue-300);box-shadow:var(--shadow-sm)}.router-select-bar{align-items:center;gap:var(--space-sm);margin-bottom:20px;display:flex}.router-select{border-radius:var(--radius-sm);border:1px solid var(--border-default);background:var(--bg-surface-1);color:var(--text-primary);font-size:var(--text-sm);min-width:250px;padding:8px 12px}.no-routers-message{text-align:center;color:var(--text-muted);background:var(--bg-surface-2);border:2px dashed var(--border-default);border-radius:var(--radius-md);padding:48px}.history-drawer{padding:8px 0}.client-status-overview{flex-direction:column;gap:16px;margin-bottom:24px;display:flex}.client-status-card{background:linear-gradient(135deg, var(--bg-surface-2), var(--bg-surface-3));border:1px solid var(--border-default);box-shadow:var(--shadow-sm);border-radius:12px;padding:20px;transition:transform .2s,box-shadow .2s}.client-status-card:hover{box-shadow:var(--shadow-md)}.client-status-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;display:grid}.client-detail-card{background:var(--bg-surface-2);border:1px solid var(--border-default);border-radius:10px;flex-direction:column;gap:8px;padding:16px;transition:border-color .2s;display:flex}.client-detail-card:hover{border-color:var(--blue-500)}.timeline{gap:var(--space-lg);flex-direction:column;padding-left:20px;display:flex;position:relative}.timeline:before{content:"";background-color:var(--border-default);width:2px;position:absolute;top:8px;bottom:8px;left:4px}.timeline-item{position:relative}.timeline-dot{background-color:var(--blue-500);border:2px solid var(--bg-surface-1);z-index:1;background-color:var(--blue-500);border:2px solid var(--bg-surface-1);z-index:1;border-radius:50%;width:10px;height:10px;position:absolute;top:8px;left:-20px}.timeline-content{background-color:var(--bg-surface-2);border-radius:var(--radius-lg);padding:var(--space-md);border:1px solid var(--border-default)}.timeline-date{font-size:var(--text-xs);color:var(--text-secondary);margin-bottom:8px;font-weight:600;display:block}.timeline-status{color:var(--text-primary);font-weight:700;font-size:var(--text-sm);align-items:center;gap:8px;margin-bottom:8px;display:flex}.status-old{color:var(--text-muted);font-weight:500;text-decoration:line-through}.arrow{color:var(--text-muted)}.status-new{color:var(--blue-300)}.timeline-reason{font-size:var(--text-sm);color:var(--text-primary);margin-bottom:4px}.timeline-trigger{font-size:var(--text-xs);color:var(--text-muted)}.filter-select{background-color:var(--bg-surface-1);border:1.5px solid var(--border-input);border-radius:var(--radius-md);height:40px;color:var(--text-primary);font-size:var(--text-sm);transition:var(--transition);cursor:pointer;outline:none;padding:0 12px}.filter-select:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #2563eb2e}@media (width<=1024px){.filter-bar{flex-direction:column;align-items:stretch}.filter-select{width:100%}}.page-header{margin-bottom:var(--space-lg)}.page-title{color:var(--text-primary);margin-bottom:4px;font-size:24px;font-weight:700}.page-subtitle{color:var(--text-secondary);margin:0;font-size:14px}.filter-bar{padding:var(--space-md) 20px;margin-bottom:var(--space-lg);border-radius:var(--radius-lg);border:1px solid var(--border-default);background-color:var(--bg-surface-1);justify-content:space-between;align-items:center;display:flex}.filter-group{align-items:center;gap:var(--space-sm);display:flex}.filter-select{border-radius:var(--radius-md);border:1px solid var(--border-input);background-color:var(--bg-surface-2);color:var(--text-primary);cursor:pointer;outline:none;min-width:180px;padding:8px 12px;font-size:14px}.filter-select:focus{border-color:var(--blue-500)}.billing-summary{align-items:center;display:flex}.client-info-cell{flex-direction:column;gap:4px;display:flex}.amount-cell{color:var(--text-primary);font-size:15px;font-weight:600}.date-cell{color:var(--text-secondary);font-weight:500}@media (width<=1024px){.filter-bar{align-items:stretch;gap:var(--space-md);flex-direction:column}.billing-summary{justify-content:flex-end}}.settings-page-container{max-width:1200px;padding:var(--space-lg);margin:0 auto}.settings-card{border-radius:var(--radius-xl,16px);border:1px solid var(--border-default);flex-direction:column;display:flex;overflow:hidden}.settings-card-header{justify-content:space-between;align-items:center;gap:var(--space-sm);padding:var(--space-md) 24px;border-bottom:1px solid var(--border-default);background-color:#00000005;display:flex}.settings-card-header-content{align-items:flex-start;gap:var(--space-sm);min-width:0;display:flex}.settings-card-header h3{color:var(--text-primary);margin:0;font-size:16px;font-weight:600}.settings-card-header p{color:var(--text-muted);margin:4px 0 0;font-size:13px}.settings-save-button{flex-shrink:0}.settings-card-actions{justify-content:space-between;align-items:center;gap:var(--space-md);padding:var(--space-md) 24px;border-top:1px solid var(--border-default);background:#00000004;display:flex}.settings-card-body{padding:var(--space-lg);gap:var(--space-lg);flex-direction:column;display:flex}.settings-section{gap:var(--space-md);border-bottom:1px solid var(--border-default);flex-direction:column;padding-bottom:24px;display:flex}.settings-section:last-child{border-bottom:0;padding-bottom:0}.settings-section--full{grid-column:1/-1}.settings-section-header{align-items:center;gap:10px;display:flex}.settings-section-header h4{color:var(--text-primary);margin:0;font-size:15px;font-weight:600}.settings-section-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;display:grid}.settings-section-grid--single{grid-template-columns:minmax(0,1fr)}.settings-span-full{grid-column:1/-1}.form-group{flex-direction:column;gap:8px;min-width:0;display:flex}.form-group label{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;display:block;overflow:hidden}.form-group input{border-radius:var(--radius-md);border:1px solid var(--border-input);background-color:var(--bg-surface-2);width:100%;color:var(--text-primary);padding:10px 14px;font-size:14px;transition:all .2s}.form-group input:focus{border-color:var(--blue-500);outline:none;box-shadow:0 0 0 3px #2563eb1a}.input-with-suffix{align-items:center;display:flex;position:relative}.input-with-suffix input{width:100%;padding-right:40px}.input-with-suffix .suffix{color:var(--text-muted);font-weight:500;position:absolute;right:14px}.helper-text{color:var(--text-muted);align-items:center;gap:6px;margin-top:4px;font-size:12px;display:flex}.last-update{color:var(--text-muted);font-size:13px}@media (width<=1024px){.settings-card-actions{flex-direction:column;align-items:stretch}.settings-card-actions .settings-save-button{width:100%}}.whatsapp-connector-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.whatsapp-connector-modal{background:var(--card-bg,#fff);border:1px solid var(--border-color,#e5e7eb);border-radius:12px;width:100%;max-width:400px;padding:2rem;position:relative;box-shadow:0 10px 25px #0003}.whatsapp-connector-modal .close-btn{color:var(--text-muted,#6b7280);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:.25rem;transition:all .2s;display:flex;position:absolute;top:1rem;right:1rem}.whatsapp-connector-modal .close-btn:hover{background:var(--surface-hover,#f3f4f6);color:var(--text-color,#111827)}.wa-status-banner{background:var(--surface-hover,#f3f4f6);border-radius:8px;align-items:center;gap:.5rem;margin-bottom:1.5rem;padding:.75rem 1rem;font-weight:500;display:flex}.wa-status-banner[data-status=connected]{color:#10b981;background:#10b9811a}.wa-status-banner[data-status=disconnected]{color:#ef4444;background:#ef44441a}.status-indicator{background:currentColor;border-radius:50%;width:10px;height:10px}.wa-status-banner[data-status=connected] .status-indicator{box-shadow:0 0 8px #10b981}.wa-status-banner[data-status=disconnected] .status-indicator{box-shadow:0 0 8px #ef4444}.mt-4{margin-top:1rem}.flex{display:flex}.flex-col{flex-direction:column;display:flex}.items-center{align-items:center}.gap-2{gap:.5rem}.w-full{width:100%}.p-8{padding:2rem}.p-4{padding:1rem}.text-center{text-align:center}.text-red{color:#ef4444}.bg-red\/10{background-color:#ef44441a}.rounded{border-radius:.25rem}.w-64{width:16rem}.h-64{height:16rem}.mx-auto{margin-left:auto;margin-right:auto}.border-4{border-width:4px}.border-white{border-color:#fff}.rounded-lg{border-radius:.5rem}.shadow-sm{box-shadow:0 1px 2px #0000000d}.text-sm{font-size:.875rem}.text-muted{color:var(--text-muted,#6b7280)}.animate-spin{animation:1s linear infinite spin}.pp-section{flex-direction:column;gap:20px;display:flex}.pp-toolbar{justify-content:space-between;align-items:flex-start;gap:var(--space-md);flex-wrap:wrap;display:flex}.pp-subtitle{color:var(--text-muted);margin:0;font-size:13px}.pp-loading{color:var(--text-muted);padding:var(--space-lg) 0;align-items:center;gap:10px;font-size:14px;display:flex}.pp-empty{border:1.5px dashed var(--border-default);border-radius:var(--radius-lg);text-align:center;color:var(--text-muted);flex-direction:column;align-items:center;gap:8px;padding:48px 24px;display:flex}.pp-empty-icon{opacity:.3;margin-bottom:8px}.pp-empty p{color:var(--text-primary);margin:0;font-size:16px;font-weight:500}.pp-empty span{max-width:340px;font-size:13px}.pp-list{flex-direction:column;gap:10px;display:flex}.pp-card{align-items:center;gap:var(--space-md);padding:var(--space-md) 20px;border-radius:var(--radius-lg);border:1px solid var(--border-default);background:var(--bg-surface-2);transition:box-shadow .2s,border-color .2s;display:flex}.pp-card:hover{border-color:var(--blue-300,#93c5fd);box-shadow:0 2px 12px #2563eb12}.pp-card-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:20px;display:flex}.pp-card-body{flex-direction:column;flex:1;gap:6px;min-width:0;display:flex}.pp-card-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:600;overflow:hidden}.pp-card-meta{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.pp-badge{letter-spacing:.02em;border-radius:99px;align-items:center;gap:4px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.pp-badge--provider{background:var(--bg-surface-3,#0000000f);color:var(--text-secondary)}.pp-badge--sandbox{color:#d97706;background:#f59e0b1f}.pp-badge--active{color:#059669;background:#10b9811f}.pp-badge--inactive{color:var(--text-muted);background:#6b72801a}.pp-card-creds{color:var(--text-muted);flex-wrap:wrap;gap:10px;font-size:12px;display:flex}.pp-card-creds span{align-items:center;gap:4px;display:flex}.pp-cred-ok{color:#10b981}.pp-cred-err{color:#ef4444}.pp-cred-warn{color:#f59e0b}.pp-cred-validated{color:#10b981}.pp-card-actions{flex-shrink:0;gap:4px;display:flex}.btn-icon{justify-content:center;align-items:center;width:36px;height:36px;padding:0;display:flex}.btn-danger-ghost:hover{color:#ef4444!important;background:#ef44441a!important}.pp-modal-overlay{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:1100;padding:var(--space-md);background:#0000008c;justify-content:center;align-items:center;animation:.15s pp-fade-in;display:flex;position:fixed;inset:0}@keyframes pp-fade-in{0%{opacity:0}to{opacity:1}}.pp-modal{background:var(--bg-surface-1);border:1px solid var(--border-default);border-radius:var(--radius-xl,16px);width:100%;max-width:520px;max-height:90vh;animation:.2s pp-slide-up;overflow-y:auto;box-shadow:0 24px 64px #00000040}@keyframes pp-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.pp-modal-header{align-items:center;gap:var(--space-sm);padding:var(--space-md) 24px;border-bottom:1px solid var(--border-default);background:var(--bg-surface-1);z-index:1;display:flex;position:sticky;top:0}.pp-modal-header h3{flex:1;margin:0;font-size:16px;font-weight:600}.pp-modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:18px;line-height:1;transition:all .15s}.pp-modal-close:hover{background:var(--bg-surface-2);color:var(--text-primary)}.pp-modal-body{padding:var(--space-lg);flex-direction:column;gap:20px;display:flex}.pp-modal-title-block{flex-direction:column;gap:4px;display:flex}.pp-modal-title-block h3{color:var(--text-primary);margin:0;font-size:18px;font-weight:600}.pp-modal-title-block p{color:var(--text-muted);margin:0;font-size:13px}.pp-provider-selector{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.pp-provider-option{border-radius:var(--radius-md);border:1.5px solid var(--border-default);cursor:pointer;text-align:center;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;transition:all .15s;display:flex;position:relative}.pp-provider-option input{opacity:0;width:0;height:0;position:absolute}.pp-provider-option:hover{border-color:var(--blue-400,#60a5fa)}.pp-provider-option--selected{background:var(--bg-surface-2)}.pp-option-icon{font-size:22px}.pp-option-label{color:var(--text-secondary);font-size:12px;font-weight:500}.pp-checkbox-row{color:var(--text-secondary);cursor:pointer;align-items:center;gap:10px;font-size:14px;display:flex}.pp-checkbox-row input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:var(--blue-500)}.pp-secret-input{align-items:center;display:flex;position:relative}.pp-secret-input input{border-radius:var(--radius-md);border:1px solid var(--border-input);background:var(--bg-surface-2);width:100%;color:var(--text-primary);padding:10px 44px 10px 14px;font-family:monospace;font-size:14px;transition:all .2s}.pp-secret-input input:focus{border-color:var(--blue-500);outline:none;box-shadow:0 0 0 3px #2563eb1a}.pp-toggle-visibility{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:4px;transition:color .15s;display:flex;position:absolute;right:10px}.pp-toggle-visibility:hover{color:var(--text-primary)}.pp-secret-badge{color:#059669;background:#10b9811f;border-radius:99px;align-items:center;gap:4px;margin-left:8px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.pp-validation-banner{border-radius:var(--radius-md);align-items:center;gap:10px;padding:12px 16px;font-size:13px;font-weight:500;display:flex}.pp-validation-banner--success{color:#059669;background:#10b9811a;border:1px solid #10b9814d}.pp-validation-banner--error{color:#dc2626;background:#ef444414;border:1px solid #ef444440}.pp-validation-banner--loading{color:var(--blue-600,#2563eb);background:#2563eb14;border:1px solid #2563eb33}.pp-warning-note{color:#d97706;border-radius:var(--radius-md);background:#f59e0b14;border:1px solid #f59e0b40;align-items:flex-start;gap:8px;padding:10px 14px;font-size:12px;line-height:1.5;display:flex}.pp-modal-actions{border-top:1px solid var(--border-default);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;padding-top:4px;display:flex}.pp-modal-actions-right{gap:8px;margin-left:auto;display:flex}.pp-spinner{animation:.8s linear infinite spin}.btn-sm{padding:8px 16px;font-size:13px}@media (width<=768px){.settings-page-container{padding:var(--space-sm,8px)}.settings-card-body{padding:var(--space-md,16px)}.settings-card-header{padding:var(--space-md,16px);flex-direction:column;align-items:flex-start;gap:12px}.settings-card-actions{padding:var(--space-md,16px)}.settings-section-grid{grid-template-columns:1fr}.mt-4.flex.gap-2{flex-direction:column}.mt-4.flex.gap-2 button{width:100%}}.password-input-wrapper{align-items:center;display:flex;position:relative}.password-input-wrapper input{width:100%;padding-right:40px}.password-toggle{cursor:pointer;color:var(--text-muted,#6b7280);background:0 0;border:none;justify-content:center;align-items:center;padding:4px;display:flex;position:absolute;right:10px}.password-toggle:hover{color:var(--text-color,#111827)}.drawer-form{flex-direction:column;gap:1.25rem;display:flex}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.checkbox-group{background-color:var(--surface-hover);border:1px solid var(--border-color);border-radius:8px;margin-top:.5rem;padding:1rem}.checkbox-label{cursor:pointer;color:var(--text-primary);align-items:center;gap:.75rem;font-weight:500;display:flex}.checkbox-label input[type=checkbox]{cursor:pointer;width:1.2rem;height:1.2rem;accent-color:var(--primary-color)}.router-tools-card{background-color:var(--bg-surface);border:1px solid var(--border-default);margin-top:var(--space-lg);border-radius:12px;overflow:hidden}.tools-tabs{background-color:var(--bg-surface-2);border-bottom:1px solid var(--border-default);display:flex}.tool-tab{color:var(--text-muted);cursor:pointer;border:none;border-right:1px solid var(--border-default);background:0 0;align-items:center;gap:8px;padding:12px 24px;font-weight:600;transition:all .2s;display:flex}.tool-tab:hover{background-color:var(--bg-surface-3);color:var(--text-default)}.tool-tab.active{background-color:var(--bg-surface);color:var(--color-primary);border-bottom:2px solid var(--color-primary)}.tool-content{padding:var(--space-lg);min-height:300px}.hidden-desktop,.mobile-only-title{display:none}.tool-input-group{gap:var(--space-sm);margin-bottom:20px;display:flex}.tool-input{border:1px solid var(--border-default);background-color:var(--bg-surface);color:var(--text-default);border-radius:8px;flex:1;padding:10px 16px}.diag-results{color:#d4d4d4;padding:var(--space-md);background-color:#1e1e1e;border-radius:8px;min-height:200px;max-height:400px;font-family:JetBrains Mono,Fira Code,monospace;font-size:13px;overflow-y:auto}.results-pre{white-space:pre-wrap;margin:0}.pool-form{gap:var(--space-sm);margin-bottom:var(--space-lg);display:flex}.pools-table{border-collapse:collapse;width:100%}.pools-table th{text-align:left;background-color:var(--bg-surface-2);border-bottom:1px solid var(--border-default);padding:8px 12px;font-size:13px}.pools-table td{border-bottom:1px solid var(--border-default);padding:8px 12px;font-size:13px}.backup-hero{text-align:center;justify-content:center;align-items:center;gap:var(--space-md);flex-direction:column;padding:40px;display:flex}.backup-hero p{color:var(--text-muted);max-width:400px}.loading-dots{color:var(--color-primary);margin-top:12px;font-style:italic}.empty-results,.empty-state{height:100%;color:var(--text-muted);justify-content:center;align-items:center;font-style:italic;display:flex}@media (width<=768px){.tools-tabs{display:none}.hidden-desktop{display:block}.mobile-only-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-default);align-items:center;gap:8px;margin-bottom:16px;padding-bottom:12px;font-size:13px;font-weight:600;display:flex}.tool-section{margin-bottom:32px}.tool-content{padding:var(--space-md)}.tool-input-group,.pool-form{flex-direction:column}.tool-input-group .btn,.pool-form .btn{width:100%}.diag-results{padding:var(--space-sm);font-size:11px}}.router-dashboard{gap:var(--space-md);flex-direction:column;display:flex}.router-dashboard-backbar{align-items:center;display:flex}.router-dashboard-back-btn{align-items:center;gap:8px;display:inline-flex}.interface-selector{margin-bottom:20px}.section-title{font-size:var(--text-sm);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:10px;font-weight:600;display:flex}.section-header-row{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.section-header-row .section-title{margin-bottom:0}.accumulated-metrics{font-size:var(--text-sm);color:var(--blue-300);background:var(--bg-surface-3);border-radius:var(--radius-pill);border:1px solid var(--border-default);align-items:center;gap:8px;padding:4px 12px;font-weight:600;display:flex}.accumulated-metrics .text-muted{font-weight:400}.selector-wrapper{gap:var(--space-sm);display:flex}.selector-wrapper select{flex:1}.monitor-placeholder{background:var(--bg-surface-2);border:2px dashed var(--border-default);border-radius:var(--radius-md);text-align:center;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;padding:48px 24px;display:flex}.placeholder-icon{margin-bottom:var(--space-md);opacity:.2}.monitor-placeholder p{max-width:300px;font-size:var(--text-sm)}.counter{padding:var(--space-xs) var(--space-sm);color:var(--accent);background:var(--accent-bg);margin-bottom:var(--space-md);border:2px solid #0000;border-radius:5px;font-size:16px;transition:border-color .3s}.counter:hover{border-color:var(--accent-border)}.counter:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.hero{position:relative}.hero .base,.hero .framework,.hero .vite{margin:0 auto;inset-inline:0}.hero .base{z-index:0;width:170px;position:relative}.hero .framework,.hero .vite{position:absolute}.hero .framework{z-index:1;height:28px;top:34px;transform:perspective(2000px)rotate(300deg)rotateX(44deg)rotateY(39deg)scale(1.4)}.hero .vite{z-index:0;width:auto;height:26px;top:107px;transform:perspective(2000px)rotate(300deg)rotateX(40deg)rotateY(39deg)scale(.8)}#center{gap:var(--space-lg);flex-direction:column;flex-grow:1;place-content:center;place-items:center;display:flex}@media (width<=1024px){#center{padding:var(--space-xl) var(--space-lg) var(--space-lg);gap:var(--space-md)}}#next-steps{border-top:1px solid var(--border);text-align:left;display:flex}#next-steps>div{padding:var(--space-lg);flex:1 1 0}@media (width<=1024px){#next-steps>div{padding:var(--space-lg) var(--space-lg)}}#next-steps .icon{margin-bottom:var(--space-md);width:22px;height:22px}@media (width<=1024px){#next-steps{text-align:center;flex-direction:column}}#docs{border-right:1px solid var(--border)}@media (width<=1024px){#docs{border-right:none;border-bottom:1px solid var(--border)}}#next-steps ul{gap:var(--space-sm);margin:var(--space-lg) 0 0;padding:0;list-style:none;display:flex}#next-steps ul .logo{height:18px}#next-steps ul a{color:var(--text-h);background:var(--social-bg);border-radius:6px;align-items:center;gap:8px;padding:6px 12px;font-size:16px;text-decoration:none;transition:box-shadow .3s;display:flex}#next-steps ul a:hover{box-shadow:var(--shadow)}#next-steps ul a .button-icon{width:18px;height:18px}@media (width<=1024px){#next-steps ul{flex-wrap:wrap;justify-content:center;margin-top:20px}#next-steps ul li{flex:calc(50% - 8px)}#next-steps ul a{box-sizing:border-box;justify-content:center;width:100%}}#spacer{border-top:1px solid var(--border);height:88px}@media (width<=1024px){#spacer{height:48px}}.ticks{width:100%;position:relative}.ticks:before,.ticks:after{content:"";border:5px solid #0000;position:absolute;top:-4.5px}.ticks:before{border-left-color:var(--border);left:0}.ticks:after{border-right-color:var(--border);right:0}
