.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-box{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;padding:40px;width:100%;max-width:400px;animation:slideIn .5s ease-out}.login-header{text-align:center;margin-bottom:30px}.login-header svg{color:var(--primary);margin-bottom:16px}.login-header h1{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.login-header p{color:var(--text-secondary);font-size:14px}.form-group{margin-bottom:20px}.form-group label{display:block;font-weight:600;color:var(--text-primary);margin-bottom:8px;font-size:14px}.form-group input{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:8px;font-size:14px;transition:var(--transition);background-color:var(--bg-primary)}.form-group input:disabled{background-color:var(--bg-tertiary);cursor:not-allowed}.error-message{background-color:#fee2e2;color:#991b1b;padding:12px;border-radius:8px;font-size:14px;margin-bottom:20px;border-left:4px solid var(--danger)}.login-button{width:100%;padding:12px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;transition:var(--transition);box-shadow:0 4px 12px #2563eb4d}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #2563eb66}.login-button:disabled{opacity:.7;cursor:not-allowed}.module-card{background:var(--surface-main);border-radius:16px;padding:28px 24px 24px;border:2px solid transparent;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;align-items:flex-start;gap:0;box-shadow:0 2px 8px #00000014;position:relative;min-height:200px}.module-card:hover{border-color:var(--primary, #3b82f6);box-shadow:0 12px 32px #2563eb26;transform:translateY(-4px)}.module-card-icon{width:72px;height:72px;border-radius:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-bottom:20px;box-shadow:0 4px 16px #0000001f;transition:all .3s ease}.module-card:hover .module-card-icon{transform:scale(1.08);box-shadow:0 8px 24px #00000029}.module-card-title{font-size:17px;font-weight:700;color:var(--text-primary, #1e293b);line-height:1.3;margin:0 0 8px;transition:color .2s ease}.module-card:hover .module-card-title{color:var(--primary, #3b82f6)}.module-card-desc{font-size:13px;color:var(--text-secondary, #64748b);line-height:1.5;margin:0;flex:1}.module-card-action{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--primary, #3b82f6);margin-top:16px;opacity:0;transform:translateY(4px);transition:all .2s ease}.module-card:hover .module-card-action{opacity:1;transform:translateY(0)}@media (max-width: 640px){.module-card{padding:22px 18px 18px;min-height:170px}.module-card-icon{width:60px;height:60px;border-radius:14px;margin-bottom:16px}.module-card-title{font-size:15px}}.company-switcher-container{position:relative;z-index:50}.company-switcher{margin:10px 12px;background:#ffffff0d;border-radius:8px;border:1px solid rgba(255,255,255,.1);transition:all .2s ease}[data-theme=light] .company-switcher{background:#00000008;border:1px solid rgba(0,0,0,.08)}.company-switcher:hover{background:#ffffff14;border-color:#fff3}[data-theme=light] .company-switcher:hover{background:#0000000d;border-color:#00000026}.company-switcher-header{padding:10px 12px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;gap:8px}.company-info{display:flex;flex-direction:column;overflow:hidden;flex:1}.company-name{font-size:13px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}[data-theme=light] .company-name{color:#1a1a1a}.filial-name{font-size:11px;color:#fff9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}[data-theme=light] .filial-name{color:#666}.chevron{color:#fff6;transition:transform .2s ease}[data-theme=light] .chevron{color:#999}.chevron.open{transform:rotate(180deg)}.company-dropdown{position:absolute;background:#1e1e2d;border:1px solid rgba(255,255,255,.1);border-radius:8px;box-shadow:0 10px 25px #0006;z-index:1000;padding:8px 0;animation:fadeIn .2s ease;min-width:200px}.company-dropdown.expanded{top:calc(100% + 5px);left:12px;right:12px}.company-dropdown.collapsed{top:0;left:100%;margin-left:10px}[data-theme=light] .company-dropdown{background:#fff;border:1px solid rgba(0,0,0,.1);box-shadow:0 10px 25px #0000001a}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-section{padding:0;display:flex;flex-direction:column}.dropdown-header{padding:8px 12px 4px;display:flex;flex-direction:column;gap:8px}.dropdown-section label{display:block;font-size:10px;text-transform:uppercase;color:#fff6;font-weight:700;letter-spacing:.5px}[data-theme=light] .dropdown-section label{color:#999}.dropdown-search{position:relative}.dropdown-search input{width:100%;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:4px;padding:6px 10px;font-size:11px;color:#fff;outline:none;transition:all .2s ease}[data-theme=light] .dropdown-search input{background:#00000008;border:1px solid rgba(0,0,0,.1);color:#000}.dropdown-search input:focus{border-color:#6366f1;background:#6366f10d}.dropdown-scroll{max-height:250px;overflow-y:auto;padding:4px 0}.dropdown-scroll.no-max{max-height:150px}.dropdown-scroll::-webkit-scrollbar{width:4px}.dropdown-scroll::-webkit-scrollbar-track{background:transparent}.dropdown-scroll::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}[data-theme=light] .dropdown-scroll::-webkit-scrollbar-thumb{background:#0000001a}.dropdown-empty{padding:12px;font-size:11px;color:#fff6;text-align:center;font-style:italic}[data-theme=light] .dropdown-empty{color:#999}.filiais-section{border-top:1px solid rgba(255,255,255,.1);margin-top:4px;padding-top:8px}[data-theme=light] .filiais-section{border-top:1px solid rgba(0,0,0,.08)}.filiais-section label{padding:0 12px 4px}.dropdown-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;cursor:pointer;transition:all .2s ease;gap:8px}.dropdown-item:hover{background:#ffffff0d}[data-theme=light] .dropdown-item:hover{background:#00000008}.dropdown-item.active{color:#6366f1;background:#6366f11a}.item-content{display:flex;align-items:center;gap:10px;overflow:hidden}.item-content span{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.company-switcher-collapsed{display:flex;align-items:center;justify-content:center;padding:12px 0;color:#fff6;cursor:pointer;transition:all .2s ease;margin:4px 0}[data-theme=light] .company-switcher-collapsed{color:#666}.company-switcher-collapsed:hover{color:#fff;background:#ffffff0d}[data-theme=light] .company-switcher-collapsed:hover{color:#1a1a1a;background:#00000008}.sidebar{position:fixed;top:0;left:0;height:100vh;background:var(--bg-sidebar);display:flex;flex-direction:column;z-index:200;transition:width .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-lg);border-right:1px solid var(--border)}.sidebar.collapsed{width:64px;overflow:visible}.sidebar.expanded{width:240px;overflow:visible}.sidebar-logo{display:flex;align-items:center;gap:12px;padding:16px;cursor:pointer;flex-shrink:0;border-bottom:1px solid rgba(255,255,255,.08)}.sidebar-logo-icon{width:32px;height:32px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));box-shadow:0 2px 10px var(--primary-glow);border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;color:#fff;flex-shrink:0}.sidebar-logo-text{font-size:18px;font-weight:700;color:#fff;white-space:nowrap;letter-spacing:-.5px}.sidebar-toggle{display:flex;align-items:center;justify-content:center;width:100%;padding:8px 0;background:none;border:none;color:#fff6;cursor:pointer;transition:color .2s;flex-shrink:0}.sidebar-toggle:hover{color:#ffffffb3}.sidebar-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:8px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.sidebar-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;cursor:pointer;transition:all .2s ease;margin-bottom:2px;position:relative}.sidebar-item:hover{background:#ffffff14}.sidebar-item.active{background:#3b82f626}.sidebar-item.active .sidebar-item-icon{color:#3b82f6}.sidebar-item.active .sidebar-item-label{color:#fff;font-weight:600}.sidebar-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:#3b82f6;border-radius:0 3px 3px 0}.sidebar-item-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;color:#ffffff80;flex-shrink:0;transition:color .2s}.sidebar-item:hover .sidebar-item-icon{color:#fffc}.sidebar-item-label{font-size:13px;color:#ffffffa6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .2s}.sidebar-item:hover .sidebar-item-label{color:#ffffffe6}.sidebar-divider{height:1px;background:#ffffff14;margin:6px 12px}.sidebar-back{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;cursor:pointer;color:#ffffff80;font-size:13px;transition:all .2s;margin-bottom:2px}.sidebar-back:hover{background:#ffffff14;color:#ffffffe6}.sidebar-module-title{padding:6px 12px 2px;font-size:11px;font-weight:700;color:#ffffff59;text-transform:uppercase;letter-spacing:.8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-menu-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:6px;cursor:pointer;transition:all .15s ease;margin-bottom:1px}.sidebar-menu-item:hover{background:#ffffff14}.sidebar-menu-item.active{background:#3b82f626}.sidebar-menu-item.active .sidebar-menu-item-label{color:#fff;font-weight:600}.sidebar-menu-item.active .sidebar-menu-item-icon{color:#3b82f6}.sidebar-menu-item-icon{display:flex;align-items:center;justify-content:center;width:16px;flex-shrink:0;color:#fff6;font-size:12px;transition:color .15s}.sidebar-menu-item:hover .sidebar-menu-item-icon{color:#ffffffb3}.sidebar-menu-item-label{font-size:13px;color:#fff9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .15s;line-height:1.3}.sidebar-menu-item:hover .sidebar-menu-item-label{color:#ffffffe6}.sidebar-menu-item.branch .sidebar-menu-item-label{font-weight:600;color:#ffffffb3}.sidebar-footer{padding:8px;border-top:1px solid rgba(255,255,255,.08);flex-shrink:0}.sidebar-user{display:block;padding:6px 12px;font-size:12px;color:#fff6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-item.logout:hover{background:#ef44441f}.sidebar-item.logout:hover .sidebar-item-icon,.sidebar-item.logout:hover .sidebar-item-label{color:#ef4444}.sidebar.collapsed .sidebar-item{justify-content:center;padding:10px}.sidebar.collapsed .sidebar-item-icon{width:22px;height:22px}.sidebar.collapsed .sidebar-back{justify-content:center}.sidebar.collapsed .sidebar-menu-item{justify-content:center;padding:10px}.sidebar-tooltip-portal{position:fixed;transform:translateY(-50%);background:#1e293b;color:#fff;padding:6px 14px;border-radius:6px;font-size:12px;font-weight:500;white-space:nowrap;pointer-events:none;z-index:9999;box-shadow:0 4px 12px #00000059;animation:tooltipFadeIn .12s ease-out}.sidebar-tooltip-portal:before{content:"";position:absolute;right:100%;top:50%;transform:translateY(-50%);border:5px solid transparent;border-right-color:#1e293b}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateY(-50%) translate(4px)}to{opacity:1;transform:translateY(-50%) translate(0)}}.dashboard-with-sidebar{margin-left:64px;transition:margin-left .25s cubic-bezier(.4,0,.2,1);min-height:100vh}@media (max-width: 768px){.sidebar.expanded{width:100vw}.dashboard-with-sidebar,.dashboard-with-sidebar.sidebar-expanded{margin-left:0}}.menu-card{background:var(--surface-main);border-radius:12px;padding:20px;border:1px solid var(--border);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow-sm)}.menu-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(-1px)}.menu-card-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-inverse);font-size:20px}.menu-card-info{flex:1;min-width:0}.menu-card-title{font-size:15px;font-weight:600;color:var(--text-primary, #1e293b);margin:0;line-height:1.3;transition:color .2s}.menu-card:hover .menu-card-title{color:var(--primary, #3b82f6)}.menu-card-count{font-size:12px;color:var(--text-secondary, #64748b);margin:4px 0 0}.menu-card-arrow{color:var(--text-tertiary, #94a3b8);flex-shrink:0;transition:all .2s}.menu-card:hover .menu-card-arrow{color:var(--primary, #3b82f6);transform:translate(2px)}.menu-breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:24px;flex-wrap:wrap}.menu-breadcrumb-item{font-size:14px;color:var(--text-secondary, #64748b);cursor:pointer;transition:color .2s;background:none;border:none;padding:0;font-family:inherit}.menu-breadcrumb-item:hover{color:var(--primary, #3b82f6)}.menu-breadcrumb-item.current{color:var(--text-primary, #1e293b);font-weight:600;cursor:default}.menu-breadcrumb-sep{color:var(--text-tertiary, #94a3b8);font-size:12px}.menu-content-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.menu-content-header h2{font-size:24px;font-weight:700;color:var(--text-primary)}.menu-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}.menu-content-empty,.menu-content-loading{text-align:center;padding:60px 20px;color:var(--text-secondary);font-size:14px}@media (max-width: 768px){.menu-cards-grid{grid-template-columns:1fr}.menu-card{padding:16px}.menu-card-icon{width:42px;height:42px}}.cortex-page{padding:24px 32px;min-height:calc(100vh - 65px);background-color:transparent}.cortex-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;background:var(--surface-main);padding:20px 28px;border-radius:16px;box-shadow:var(--header-shadow);border:1px solid var(--border);transition:var(--transition)}.cortex-header-left{display:flex;align-items:center;gap:16px}.cortex-header-left h2{font-size:24px;font-weight:800;color:var(--text-primary);margin:0;letter-spacing:-.5px}.cortex-header-actions{display:flex;align-items:center;gap:12px}.btn-back{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--surface-main);border:1px solid var(--border-input);border-radius:10px;color:var(--text-secondary);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-sm)}.btn-back:hover{border-color:var(--border-input-hover);color:var(--text-primary);background:var(--surface-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-primary{display:flex;align-items:center;gap:6px;padding:8px 18px;background:var(--primary);border:none;border-radius:10px;color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px var(--primary-glow)}.btn-primary:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 6px 16px var(--primary-glow)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-danger{display:flex;align-items:center;gap:6px;padding:8px 18px;background:var(--surface-main);border:1px solid var(--danger-border);border-radius:10px;color:var(--danger);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-sm)}.btn-danger:hover{background:var(--danger-bg);border-color:var(--danger);transform:translateY(-1px);box-shadow:0 4px 12px #ef444426}.btn-add-inline{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;background:var(--primary-glow);border:1px solid var(--primary);border-radius:8px;color:var(--primary);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-add-inline:hover{background:var(--primary);color:#fff}.cortex-message{padding:12px 24px;font-size:13px;font-weight:500;margin-bottom:24px;border-radius:8px;display:flex;align-items:center;gap:8px}.cortex-message.success{background:var(--success-bg);color:var(--success);border-left:4px solid var(--success)}.cortex-message.error{background:var(--danger-bg);color:var(--danger);border-left:4px solid var(--danger)}.cortex-form-container{display:flex;justify-content:center;width:100%}.cortex-form{width:100%;max-width:1100px;background:var(--surface-main);border-radius:16px;padding:40px 48px;box-shadow:var(--form-shadow);border:1px solid var(--border);box-sizing:border-box;transition:var(--transition);animation:formSlideUp .5s cubic-bezier(.16,1,.3,1)}@keyframes formSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.cortex-form-loading{display:flex;align-items:center;justify-content:center;gap:12px;height:300px;color:var(--text-secondary);font-size:15px}.cortex-form-title{font-size:20px;font-weight:800;color:var(--text-primary);margin-top:40px;margin-bottom:24px;padding-bottom:12px;border-bottom:1px solid var(--border);display:flex;align-items:center;position:relative;letter-spacing:-.3px}.cortex-form-title:after{content:"";position:absolute;bottom:-1px;left:0;width:60px;height:3px;border-radius:3px;background-color:var(--primary);box-shadow:0 0 10px var(--primary-glow)}.cortex-form-title:first-child{margin-top:0}.cortex-form-grid{display:grid;grid-template-columns:repeat(4,1fr);column-gap:20px;row-gap:16px;margin-bottom:24px}.cortex-form-grid.cols-1{grid-template-columns:1fr}.cortex-form-grid.cols-2{grid-template-columns:repeat(2,1fr)}.cortex-form-grid.cols-3{grid-template-columns:repeat(3,1fr)}.cortex-form-group{display:flex;flex-direction:column;gap:8px}.cortex-form-group.full,.cortex-form-group.span4{grid-column:1 / -1}.cortex-form-group.span2{grid-column:span 2}.cortex-form-group.span3{grid-column:span 3}.cortex-form-group label{font-size:13px;font-weight:600;color:var(--text-secondary);display:flex;align-items:center;gap:6px;margin:0}.cortex-form-group input,.cortex-form-group select{width:100%;height:46px;padding:0 16px;border:1px solid var(--border-input);border-radius:10px;font-size:14px;color:var(--text-primary);background-color:var(--input-bg);outline:none;transition:all .2s ease;box-sizing:border-box;font-family:inherit;box-shadow:inset 0 1px 2px #0000000a}.cortex-form-group input:hover:not([readOnly]),.cortex-form-group select:hover:not([readOnly]){border-color:var(--border-input-hover)}.cortex-form-group input:focus:not([readOnly]),.cortex-form-group select:focus:not([readOnly]){border-color:var(--primary);background-color:var(--input-bg-focus);box-shadow:0 0 0 4px var(--border-focus)}.cortex-form-group input::placeholder{color:var(--text-tertiary);font-weight:400}.cortex-form-group input[readOnly]{background-color:var(--input-bg-disabled);border-color:var(--border);color:var(--text-tertiary);cursor:default;box-shadow:none}.cortex-textarea{width:100%;padding:14px;border:1px solid var(--border-input);border-radius:8px;font-size:14px;color:var(--text-primary);background-color:var(--input-bg);outline:none;transition:all .2s ease;resize:vertical;min-height:100px;font-family:inherit;box-sizing:border-box;box-shadow:0 1px 2px #00000005 inset}.cortex-textarea:focus{border-color:var(--primary);background-color:var(--input-bg-focus);box-shadow:0 0 0 3px var(--border-focus)}.cortex-form-hint{font-size:11px;color:var(--text-tertiary);margin-top:2px}@media (max-width: 1024px){.cortex-form-grid{grid-template-columns:repeat(2,1fr)}.cortex-form-group.span3,.cortex-form-group.span4{grid-column:span 2}}@media (max-width: 768px){.cortex-page{padding:12px}.cortex-header{flex-direction:column;align-items:flex-start;gap:16px;padding:16px}.cortex-header-actions{width:100%;justify-content:flex-end}.cortex-form{padding:24px 20px}.cortex-form-grid{grid-template-columns:1fr;gap:16px}.cortex-form-group.span2,.cortex-form-group.span3,.cortex-form-group.span4{grid-column:span 1}}.menu-admin{min-height:100vh;background:var(--bg-secondary)}.menu-admin-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:#fff;border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm)}.menu-admin-header-left{display:flex;align-items:center;gap:16px}.menu-admin-header-left h2{font-size:18px;font-weight:700;color:var(--text-primary)}.menu-admin-message{padding:10px 24px;font-size:13px;font-weight:500}.menu-admin-message.success{background:#ecfdf5;color:#047857;border-bottom:1px solid #a7f3d0}.menu-admin-message.error{background:#fef2f2;color:#b91c1c;border-bottom:1px solid #fca5a5}.menu-admin-loading{text-align:center;padding:60px;color:var(--text-secondary)}.menu-admin-body{display:flex;height:calc(100vh - 65px)}.menu-admin-tree-panel{width:340px;flex-shrink:0;background:#fff;border-right:1px solid var(--border);display:flex;flex-direction:column}.tree-search{display:flex;align-items:center;gap:8px;padding:12px 14px;border-bottom:1px solid var(--border);color:var(--text-tertiary)}.tree-search input{flex:1;border:none;outline:none;font-size:13px;color:var(--text-primary);background:none}.tree-list{flex:1;overflow-y:auto;padding:8px 0}.tree-empty{text-align:center;padding:30px;color:var(--text-secondary);font-size:13px}.tree-module-group{border-bottom:1px solid var(--border)}.tree-module-group:last-child{border-bottom:none}.tree-module-header{display:flex;align-items:center;gap:8px;padding:10px 12px;cursor:pointer;font-size:13px;font-weight:700;color:var(--text-primary);background:var(--bg-tertiary, #f8fafc);-webkit-user-select:none;user-select:none;transition:background .15s;position:sticky;top:0;z-index:1}.tree-module-header:hover{background:#eef2f7}.tree-module-toggle{display:flex;align-items:center;color:var(--text-tertiary)}.tree-module-icon{color:var(--primary, #2563eb);flex-shrink:0}.tree-module-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tree-module-count{font-size:11px;font-weight:600;color:var(--text-tertiary);background:var(--border, #e2e8f0);padding:1px 7px;border-radius:10px;flex-shrink:0}.tree-item{display:flex;align-items:center;gap:6px;padding:7px 12px;cursor:pointer;font-size:13px;color:var(--text-primary);transition:background .1s;-webkit-user-select:none;user-select:none}.tree-item:hover{background:var(--bg-tertiary)}.tree-item.selected{background:var(--primary-light);color:var(--primary);font-weight:600}.tree-item-toggle{display:flex;align-items:center;justify-content:center;width:18px;flex-shrink:0;color:var(--text-tertiary);cursor:pointer}.tree-item-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tree-item-link-badge{color:var(--text-tertiary);flex-shrink:0}.menu-admin-form-panel{flex:1;overflow-y:auto;padding:14px 20px;background:#fff}.form-empty{display:flex;align-items:center;justify-content:center;height:300px;color:var(--text-secondary);font-size:14px}.link-type-badge{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:500;color:var(--primary);background:var(--primary-light, #eff6ff);padding:1px 6px;border-radius:3px;text-transform:none;letter-spacing:0}.icon-selector{border:1px solid #e2e8f0;border-radius:6px;overflow:hidden;background:#fafbfd}.icon-search{display:flex;align-items:center;gap:6px;padding:6px 10px;border-bottom:1px solid #e2e8f0;color:#a0aec0}.icon-search input{flex:1;border:none!important;outline:none;font-size:12px;padding:0!important;box-shadow:none!important;background:transparent;height:auto!important}.icon-grid{display:flex;flex-wrap:wrap;gap:3px;padding:8px;max-height:140px;overflow-y:auto}.icon-option{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:1px solid transparent;border-radius:4px;cursor:pointer;color:var(--text-secondary);font-size:14px;transition:all .15s}.icon-option:hover{background:#edf2f7;border-color:#cbd5e1}.icon-option.selected{background:var(--primary-light, #eff6ff);border-color:var(--primary);color:var(--primary)}.form-actions{display:flex;gap:8px;margin-top:18px;padding-top:14px;border-top:1px solid #e2e8f0}@media (max-width: 768px){.menu-admin-body{flex-direction:column;height:auto}.menu-admin-tree-panel{width:100%;max-height:300px;border-right:none;border-bottom:1px solid var(--border)}.form-grid{grid-template-columns:1fr}}.datagrid{display:flex;flex-direction:column;height:100%;background:var(--surface-main);border-radius:8px;box-shadow:var(--shadow-sm);overflow:hidden}.datagrid-toolbar{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid var(--border);gap:12px;flex-shrink:0}.datagrid-search{display:flex;align-items:center;gap:0;border:1px solid var(--border-input);border-radius:4px;overflow:hidden;background:var(--input-bg);flex:1;max-width:360px}.datagrid-search-icon{margin-left:8px;color:var(--text-tertiary);flex-shrink:0}.datagrid-search-input{flex:1;border:none;outline:none;padding:6px 8px;font-size:13px;background:transparent;color:var(--text-primary)}.datagrid-search-input::placeholder{color:var(--text-tertiary)}.datagrid-search-btn{display:flex;align-items:center;justify-content:center;padding:6px 10px;background:var(--primary, #2563eb);border:none;color:#fff;cursor:pointer;transition:background .2s}.datagrid-search-btn:hover{background:var(--primary-dark, #1d4ed8)}.datagrid-toolbar-actions{display:flex;gap:8px}.datagrid-btn-new{padding:6px 16px;background:#10b981;border:none;border-radius:4px;color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:background .2s}.datagrid-btn-new:hover{background:#059669}.datagrid-table-wrap{flex:1;overflow:auto}.datagrid-table{width:100%;border-collapse:collapse;font-size:13px}.datagrid-table thead{position:sticky;top:0;z-index:1}.datagrid-table th{background:var(--surface-main);color:var(--text-secondary);font-weight:600;font-size:12px;padding:8px 12px;text-align:left;border-bottom:2px solid var(--border);white-space:nowrap;-webkit-user-select:none;user-select:none}.datagrid-table th.sortable{cursor:pointer}.datagrid-table th.sortable:hover{background:var(--surface-hover)}.datagrid-th-content{display:flex;align-items:center;gap:4px}.datagrid-sort-icon{color:var(--primary, #2563eb);display:flex}.datagrid-th-action{width:40px}.datagrid-table td{padding:6px 12px;border-bottom:1px solid var(--border);color:var(--text-primary);max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.datagrid-table tr.even{background:var(--surface-main)}.datagrid-table tr.odd{background:var(--surface-hover)}.datagrid-table tbody tr:hover{background:var(--bg-tertiary)}.datagrid-td-action{text-align:center}.datagrid-edit-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--border-input);border-radius:4px;background:var(--surface-main);color:var(--text-secondary);cursor:pointer;transition:all .15s}.datagrid-edit-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.datagrid-loading,.datagrid-empty{text-align:center;padding:40px!important;color:var(--text-tertiary);font-size:14px}.datagrid-loading{display:flex;align-items:center;justify-content:center;gap:8px}@keyframes spin{to{transform:rotate(360deg)}}.spinner{animation:spin 1s linear infinite}.datagrid-pagination{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;border-top:1px solid var(--border);flex-shrink:0;background:var(--surface-main)}.datagrid-pagination-info{font-size:12px;color:var(--text-secondary)}.datagrid-pagination-controls{display:flex;align-items:center;gap:2px}.datagrid-pagination-controls button{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--border-input);border-radius:3px;background:var(--surface-main);color:var(--text-secondary);cursor:pointer;transition:all .15s}.datagrid-pagination-controls button:hover:not(:disabled){border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.datagrid-pagination-controls button:disabled{opacity:.4;cursor:not-allowed}.datagrid-page-indicator{font-size:12px;color:var(--text-secondary);padding:0 8px;min-width:50px;text-align:center}@media (max-width: 768px){.datagrid-toolbar{flex-direction:column;align-items:stretch}.datagrid-search{max-width:100%}}.react-grid-layout{position:relative;transition:height .2s ease}.react-grid-item{transition:all .2s ease;transition-property:left,top,width,height}.react-grid-item img{pointer-events:none;-webkit-user-select:none;user-select:none}.react-grid-item.cssTransforms{transition-property:transform,width,height}.react-grid-item.resizing{transition:none;z-index:1;will-change:width,height}.react-grid-item.react-draggable-dragging{transition:none;z-index:3;will-change:transform}.react-grid-item.dropping{visibility:hidden}.react-grid-item.react-grid-placeholder{background:red;opacity:.2;transition-duration:.1s;z-index:2;-webkit-user-select:none;user-select:none}.react-grid-item.react-grid-placeholder.placeholder-resizing{transition:none}.react-grid-item>.react-resizable-handle{position:absolute;width:20px;height:20px;opacity:0}.react-grid-item:hover>.react-resizable-handle{opacity:1}.react-grid-item>.react-resizable-handle:after{content:"";position:absolute;right:3px;bottom:3px;width:5px;height:5px;border-right:2px solid rgba(0,0,0,.4);border-bottom:2px solid rgba(0,0,0,.4)}.react-resizable-hide>.react-resizable-handle{display:none}.react-grid-item>.react-resizable-handle.react-resizable-handle-sw{bottom:0;left:0;cursor:sw-resize;transform:rotate(90deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-se{bottom:0;right:0;cursor:se-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-nw{top:0;left:0;cursor:nw-resize;transform:rotate(180deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-ne{top:0;right:0;cursor:ne-resize;transform:rotate(270deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-w,.react-grid-item>.react-resizable-handle.react-resizable-handle-e{top:50%;margin-top:-10px;cursor:ew-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-n,.react-grid-item>.react-resizable-handle.react-resizable-handle-s{left:50%;margin-left:-10px;cursor:ns-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}.react-resizable{position:relative}.react-resizable-handle{position:absolute;width:20px;height:20px;background-repeat:no-repeat;background-origin:content-box;box-sizing:border-box;background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA2IDYiIHN0eWxlPSJiYWNrZ3JvdW5kLWNvbG9yOiNmZmZmZmYwMCIgeD0iMHB4IiB5PSIwcHgiIHdpZHRoPSI2cHgiIGhlaWdodD0iNnB4Ij48ZyBvcGFjaXR5PSIwLjMwMiI+PHBhdGggZD0iTSA2IDYgTCAwIDYgTCAwIDQuMiBMIDQgNC4yIEwgNC4yIDQuMiBMIDQuMiAwIEwgNiAwIEwgNiA2IEwgNiA2IFoiIGZpbGw9IiMwMDAwMDAiLz48L2c+PC9zdmc+);background-position:bottom right;padding:0 3px 3px 0}.react-resizable-handle-sw{bottom:0;left:0;cursor:sw-resize;transform:rotate(90deg)}.react-resizable-handle-se{bottom:0;right:0;cursor:se-resize}.react-resizable-handle-nw{top:0;left:0;cursor:nw-resize;transform:rotate(180deg)}.react-resizable-handle-ne{top:0;right:0;cursor:ne-resize;transform:rotate(270deg)}.react-resizable-handle-w,.react-resizable-handle-e{top:50%;margin-top:-10px;cursor:ew-resize}.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-resizable-handle-n,.react-resizable-handle-s{left:50%;margin-left:-10px;cursor:ns-resize}.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}.bi-theme{--bi-bg: #f0f2f5;--bi-card-bg: #ffffff;--bi-card-border: #e2e8f0;--bi-card-shadow: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--bi-card-shadow-hover: 0 8px 25px rgba(0, 0, 0, .1);--bi-primary: #2563eb;--bi-primary-dark: #1d4ed8;--bi-primary-light: #eff6ff;--bi-success: #059669;--bi-success-light: #ecfdf5;--bi-warning: #d97706;--bi-warning-light: #fffbeb;--bi-danger: #dc2626;--bi-danger-light: #fef2f2;--bi-text: #1e293b;--bi-text-secondary: #64748b;--bi-text-muted: #94a3b8;--bi-border: #e2e8f0;--bi-radius: 12px;--bi-radius-sm: 8px;--bi-radius-xs: 6px;--bi-transition: .2s cubic-bezier(.4, 0, .2, 1)}.bi-dashboard-view-wrap{background:var(--bi-bg);min-height:100%;padding:20px;display:flex;flex-direction:column;gap:16px}.bi-dashboard-view-wrap .bi-dashboard-view-desc{color:var(--bi-text-secondary);margin:0;font-size:.9rem}.bi-global-filters{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bi-card-bg);border:1px solid var(--bi-border);border-radius:var(--bi-radius-sm);flex-wrap:wrap;box-shadow:var(--bi-card-shadow)}.bi-global-filters-label{font-size:.8rem;font-weight:600;color:var(--bi-text-secondary);text-transform:uppercase;letter-spacing:.04em;display:flex;align-items:center;gap:6px;flex-shrink:0}.bi-filter-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:var(--bi-primary-light);border:1px solid #bfdbfe;border-radius:20px;font-size:.8rem;color:var(--bi-primary-dark);cursor:pointer;transition:all var(--bi-transition)}.bi-filter-chip:hover{background:#dbeafe;border-color:var(--bi-primary)}.bi-filter-chip-remove{display:flex;align-items:center;padding:0;border:none;background:none;cursor:pointer;color:var(--bi-primary);opacity:.6;transition:opacity var(--bi-transition)}.bi-filter-chip-remove:hover{opacity:1}.bi-filter-add-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border:1px dashed var(--bi-border);border-radius:20px;background:transparent;font-size:.8rem;color:var(--bi-text-muted);cursor:pointer;transition:all var(--bi-transition)}.bi-filter-add-btn:hover{border-color:var(--bi-primary);color:var(--bi-primary);background:var(--bi-primary-light)}.bi-filter-clear-btn{padding:4px 10px;border:none;border-radius:4px;background:transparent;font-size:.75rem;color:var(--bi-text-muted);cursor:pointer;margin-left:auto}.bi-filter-clear-btn:hover{color:var(--bi-danger);background:var(--bi-danger-light)}.bi-filter-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:1000;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.bi-filter-modal{background:var(--bi-card-bg);border-radius:var(--bi-radius);padding:24px;width:400px;max-width:90vw;box-shadow:0 20px 60px #0003}.bi-filter-modal h4{margin:0 0 16px;font-size:1rem;color:var(--bi-text)}.bi-filter-modal-field{margin-bottom:14px}.bi-filter-modal-field label{display:block;font-size:.8rem;font-weight:500;color:var(--bi-text-secondary);margin-bottom:4px}.bi-filter-modal-field select,.bi-filter-modal-field input{width:100%;padding:8px 10px;border:1px solid var(--bi-border);border-radius:var(--bi-radius-xs);font-size:.875rem;background:#fff;transition:border-color var(--bi-transition)}.bi-filter-modal-field select:focus,.bi-filter-modal-field input:focus{outline:none;border-color:var(--bi-primary);box-shadow:0 0 0 3px #2563eb1a}.bi-filter-modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:20px}.bi-view-layout{display:flex;gap:0;width:100%;overflow:hidden}.bi-view-grid-wrapper{flex:1;min-width:0;align-self:start}.bi-view-panel-spacer{width:280px;flex-shrink:0}.bi-widgets-view-grid{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:60px;gap:16px;align-items:stretch;max-width:100%}.bi-widget-view-wrap{min-height:0;background:var(--bi-card-bg);border:1px solid var(--bi-card-border);border-radius:var(--bi-radius);padding:0;box-shadow:var(--bi-card-shadow);transition:box-shadow var(--bi-transition),border-color var(--bi-transition),transform var(--bi-transition);display:flex;flex-direction:column;overflow:hidden;cursor:pointer}.bi-widget-view-wrap:hover{box-shadow:var(--bi-card-shadow-hover);border-color:#cbd5e1;transform:translateY(-1px)}.bi-widget-view-wrap.bi-widget-cross-active{border-color:var(--bi-primary);box-shadow:0 0 0 2px #2563eb33,var(--bi-card-shadow-hover)}.bi-widget-view-wrap .bi-widget-view{flex:1;min-height:0;display:flex;flex-direction:column;padding:16px;gap:8px}.bi-widget-view{display:flex;flex-direction:column;gap:12px;height:100%}.bi-widget-view-title{font-weight:600;color:var(--bi-text);font-size:.95rem}.bi-widget-header{display:flex;align-items:center;justify-content:space-between;gap:8px;padding-bottom:8px}.bi-widget-header-title{font-weight:600;font-size:.9rem;color:var(--bi-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bi-widget-header-actions{display:flex;align-items:center;gap:4px;opacity:0;transition:opacity var(--bi-transition)}.bi-widget-view-wrap:hover .bi-widget-header-actions,.bi-widget-box:hover .bi-widget-header-actions{opacity:1}.bi-widget-action-btn{padding:4px;border:none;background:transparent;cursor:pointer;color:var(--bi-text-muted);border-radius:4px;display:flex;align-items:center;transition:all var(--bi-transition)}.bi-widget-action-btn:hover{color:var(--bi-primary);background:var(--bi-primary-light)}.bi-widget-empty{justify-content:center;align-items:center;text-align:center;color:var(--bi-text-secondary);padding:24px}.bi-widget-empty small{font-size:.8rem;color:var(--bi-text-muted)}.bi-widget-loading{align-items:center;justify-content:center;min-height:120px;color:var(--bi-text-muted)}.bi-widget-loading .spin,.spin{animation:bi-spin .8s linear infinite}@keyframes bi-spin{to{transform:rotate(360deg)}}.bi-widget-error{padding:16px}.bi-widget-error small{color:var(--bi-danger);font-size:.85rem}.bi-widget-kpi{justify-content:center;align-items:center;padding:16px;text-align:center;position:relative}.bi-widget-kpi .bi-widget-kpi-label{font-size:.8rem;font-weight:600;color:var(--bi-text-secondary);text-transform:uppercase;letter-spacing:.04em}.bi-widget-kpi .bi-widget-kpi-value{font-size:2.25rem;font-weight:700;color:var(--bi-text);letter-spacing:-.02em;line-height:1.2}.bi-widget-kpi .bi-widget-kpi-trend{display:inline-flex;align-items:center;gap:4px;font-size:.8rem;font-weight:500;padding:2px 8px;border-radius:12px;margin-top:4px}.bi-widget-kpi .bi-kpi-trend-up{color:var(--bi-success);background:var(--bi-success-light)}.bi-widget-kpi .bi-kpi-trend-down{color:var(--bi-danger);background:var(--bi-danger-light)}.bi-widget-chart{padding:16px}.bi-widget-chart .bi-widget-chart-title{font-weight:600;font-size:.9rem;color:var(--bi-text);margin-bottom:8px}.bi-widget-chart-inner{flex:1;min-height:240px}.bi-widget-chart-inner.bi-widget-chart-preview{min-height:160px}.bi-widget-gauge{justify-content:center;align-items:center;padding:16px}.bi-gauge-container{position:relative;display:flex;flex-direction:column;align-items:center;gap:8px}.bi-gauge-svg{overflow:visible}.bi-gauge-label{font-size:.8rem;font-weight:600;color:var(--bi-text-secondary);text-transform:uppercase;letter-spacing:.04em}.bi-widget-table{padding:16px}.bi-widget-table .bi-widget-table-title{font-weight:600;font-size:.9rem;color:var(--bi-text);margin-bottom:8px}.bi-widget-table-wrap{overflow-x:auto;border-radius:var(--bi-radius-sm);border:1px solid var(--bi-border)}.bi-widget-table table{width:100%;border-collapse:collapse;font-size:.82rem}.bi-widget-table th{text-align:left;padding:10px 14px;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:var(--bi-text-secondary);background:var(--bi-bg);border-bottom:2px solid var(--bi-border);white-space:nowrap}.bi-widget-table td{padding:10px 14px;border-bottom:1px solid #f1f5f9;color:var(--bi-text)}.bi-widget-table tbody tr:last-child td{border-bottom:none}.bi-widget-table tbody tr:hover{background:var(--bi-primary-light)}.bi-widget-table-more{display:block;margin-top:10px;font-size:.75rem;color:var(--bi-text-muted);text-align:center}.bi-dashboard-cards{list-style:none;display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;margin:0;padding:0}.bi-dashboard-card{background:var(--bi-card-bg);border:1px solid var(--bi-card-border);border-radius:var(--bi-radius);padding:20px;box-shadow:var(--bi-card-shadow);transition:all var(--bi-transition);display:flex;flex-direction:column;gap:10px;cursor:pointer}.bi-dashboard-card:hover{box-shadow:var(--bi-card-shadow-hover);border-color:#cbd5e1;transform:translateY(-2px)}.bi-dashboard-card-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.bi-dashboard-card-header strong{font-size:1rem;color:var(--bi-text)}.bi-dashboard-card-desc{font-size:.875rem;color:var(--bi-text-secondary);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bi-dashboard-card-meta{font-size:.8rem;color:var(--bi-text-muted);margin:0}.bi-badge-publico{font-size:.7rem;background:var(--bi-primary-light);color:var(--bi-primary);padding:4px 10px;border-radius:12px;font-weight:500}.bi-dashboard-card-actions{margin-top:auto;padding-top:12px;display:flex;gap:8px}.bi-empty{text-align:center;padding:64px 24px;color:var(--bi-text-secondary)}.bi-empty svg{opacity:.3;margin-bottom:16px;color:var(--bi-text-muted)}.bi-empty-hint{font-size:.9rem;margin-top:8px;color:var(--bi-text-muted)}.bi-empty-in-view{background:var(--bi-card-bg);border-radius:var(--bi-radius);border:2px dashed var(--bi-border)}.bi-export-toolbar{display:flex;gap:8px;align-items:center}.bi-export-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border:1px solid var(--bi-border);border-radius:var(--bi-radius-xs);background:var(--bi-card-bg);font-size:.8rem;color:var(--bi-text-secondary);cursor:pointer;transition:all var(--bi-transition)}.bi-export-btn:hover{border-color:var(--bi-primary);color:var(--bi-primary);background:var(--bi-primary-light)}.bi-btn-primary{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:var(--bi-radius-sm);background:var(--bi-primary);color:#fff;font-size:.875rem;font-weight:500;cursor:pointer;transition:background var(--bi-transition)}.bi-btn-primary:hover{background:var(--bi-primary-dark)}.bi-btn-primary:disabled{opacity:.6;cursor:not-allowed}.bi-btn-secondary{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid var(--bi-border);border-radius:var(--bi-radius-sm);background:var(--bi-card-bg);color:var(--bi-text);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--bi-transition)}.bi-btn-secondary:hover{background:var(--bi-primary-light);border-color:var(--bi-primary);color:var(--bi-primary)}.bi-btn-sm{padding:6px 12px;font-size:.8rem}.bi-btn-danger{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border:none;border-radius:var(--bi-radius-xs);background:var(--bi-danger);color:#fff;font-size:.8rem;cursor:pointer;transition:background var(--bi-transition)}.bi-btn-danger:hover{background:#b91c1c}.bi-dashboard-view-wrap .btn-secondary{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;font-size:.875rem;border-radius:var(--bi-radius-sm);border:1px solid var(--bi-border);background:var(--bi-card-bg);color:var(--bi-text);cursor:pointer;transition:all var(--bi-transition)}.bi-dashboard-view-wrap .btn-secondary:hover{background:var(--bi-primary-light);border-color:var(--bi-primary);color:var(--bi-primary)}.recharts-cartesian-grid-horizontal line,.recharts-cartesian-grid-vertical line{stroke:#f1f5f9}.recharts-tooltip-wrapper .recharts-default-tooltip{border-radius:8px!important;border:1px solid var(--bi-border)!important;box-shadow:0 4px 12px #0000001a!important;padding:10px 14px!important}.bi-theme ::-webkit-scrollbar{width:6px;height:6px}.bi-theme ::-webkit-scrollbar-track{background:transparent}.bi-theme ::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.bi-theme ::-webkit-scrollbar-thumb:hover{background:#94a3b8}.bi-builder-root{display:flex;flex-direction:column;height:100vh;background:#f0f2f5;overflow:hidden}.bi-builder-topbar{display:flex;align-items:center;gap:12px;padding:0 20px;height:56px;background:#fff;border-bottom:1px solid #e2e8f0;flex-shrink:0;z-index:10}.bi-builder-back{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid #e2e8f0;border-radius:8px;background:#fff;cursor:pointer;color:#64748b;transition:all .15s;flex-shrink:0}.bi-builder-back:hover{background:#f8fafc;border-color:#cbd5e1;color:#1e293b}.bi-builder-topbar-left{display:flex;flex-direction:column;gap:1px;min-width:0;flex:1}.bi-builder-topbar-title{font-size:.9rem;font-weight:600;color:#475569}.bi-builder-name-display{display:inline-flex;align-items:center;gap:8px;border:none;background:none;cursor:pointer;padding:2px 6px;margin:-2px -6px;border-radius:6px;transition:background .15s;max-width:100%}.bi-builder-name-display:hover{background:#f1f5f9}.bi-builder-name-text{font-size:1.05rem;font-weight:700;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.01em}.bi-builder-name-pencil{color:#94a3b8;flex-shrink:0;opacity:0;transition:opacity .15s}.bi-builder-name-display:hover .bi-builder-name-pencil{opacity:1}.bi-builder-name-edit{display:flex;align-items:center;gap:6px}.bi-builder-name-input{font-size:1.05rem;font-weight:700;color:#0f172a;border:1px solid #2563eb;border-radius:6px;padding:3px 10px;background:#fff;outline:none;box-shadow:0 0 0 3px #2563eb1a;width:260px;max-width:100%}.bi-builder-name-confirm{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:6px;background:#2563eb;color:#fff;cursor:pointer;transition:background .15s;flex-shrink:0}.bi-builder-name-confirm:hover{background:#1d4ed8}.bi-builder-meta{display:flex;align-items:center;gap:10px}.bi-builder-widget-count{font-size:.72rem;color:#94a3b8;font-weight:500}.bi-builder-status{font-size:.72rem;font-weight:500;display:inline-flex;align-items:center;gap:4px}.bi-builder-status-saving{color:#d97706}.bi-builder-status-saved{color:#059669}.bi-builder-topbar-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.bi-builder-add-widgets{display:flex;gap:4px}.bi-add-widget-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border:1px solid #e2e8f0;border-radius:8px;background:#fff;font-size:.8rem;font-weight:500;cursor:pointer;color:#475569;transition:all .15s;white-space:nowrap}.bi-add-widget-btn:hover:not(:disabled){background:#eff6ff;border-color:#2563eb;color:#2563eb}.bi-add-widget-btn:disabled{opacity:.4;cursor:not-allowed}@media (max-width: 900px){.bi-add-widget-label{display:none}.bi-add-widget-btn{padding:7px 10px}}.bi-builder-body{display:flex;flex:1;overflow:hidden}.bi-builder-canvas{flex:1;overflow:auto;min-height:0}.bi-builder-canvas .react-grid-layout{background:#f0f2f5;min-height:calc(100vh - 56px)}.bi-builder-loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:64px;flex:1}.bi-widget-box{background:#fff;border:2px solid #e5e7eb;border-radius:10px;overflow:hidden;cursor:pointer;display:flex;flex-direction:column;transition:border-color .15s,box-shadow .15s}.bi-widget-box:hover{border-color:#cbd5e1;box-shadow:0 2px 8px #0000000f}.bi-widget-box.selected{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1f}.bi-widget-box-header{display:flex;align-items:center;gap:6px;padding:4px 8px 0;flex-shrink:0}.bi-widget-drag-handle{padding:4px;cursor:move;color:#9ca3af;display:flex;align-items:center;border-radius:4px;transition:color .15s,background .15s}.bi-widget-drag-handle:hover{color:#475569;background:#f1f5f9}.bi-widget-dims{font-size:.65rem;color:#9ca3af;margin-left:auto;background:#f1f5f9;padding:1px 6px;border-radius:4px;font-family:monospace}.bi-widget-trash{padding:4px;border:none;background:none;cursor:pointer;color:#9ca3af;border-radius:4px;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .15s}.bi-widget-box:hover .bi-widget-trash{opacity:1}.bi-widget-trash:hover{color:#dc2626;background:#fef2f2}.bi-widget-body{flex:1;padding:8px;display:flex;flex-direction:column;gap:4px;min-height:0;overflow:hidden}.bi-widget-body-live{overflow:auto}.bi-config-panel{width:320px;flex-shrink:0;border-left:1px solid #e2e8f0;background:#fff;overflow-y:auto;display:flex;flex-direction:column}.bi-config-panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 12px;border-bottom:1px solid #f1f5f9}.bi-config-panel-header h3{margin:0;font-size:.9rem;font-weight:700;color:#0f172a}.bi-config-close-btn{border:none;background:none;font-size:1.2rem;cursor:pointer;color:#94a3b8;padding:4px 8px;border-radius:4px;line-height:1}.bi-config-close-btn:hover{background:#f1f5f9;color:#1e293b}.bi-config-section{border-bottom:1px solid #f1f5f9}.bi-config-section-header{display:flex;align-items:center;gap:8px;width:100%;padding:11px 16px;border:none;background:none;cursor:pointer;font-size:.8rem;font-weight:600;color:#475569;text-align:left;transition:background .15s}.bi-config-section-header:hover{background:#f8fafc}.bi-config-section-icon{display:flex;align-items:center;color:#94a3b8}.bi-config-section-title{flex:1}.bi-config-section-body{padding:0 16px 14px}.bi-config-field{margin-bottom:12px}.bi-config-field>label{display:block;font-size:.7rem;font-weight:600;color:#64748b;margin-bottom:4px;text-transform:uppercase;letter-spacing:.04em}.bi-config-field input[type=text],.bi-config-field input[type=number],.bi-config-field select{width:100%;padding:7px 10px;border:1px solid #e2e8f0;border-radius:6px;font-size:.85rem;background:#fff;transition:border-color .15s}.bi-config-field input:focus,.bi-config-field select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb14}.bi-config-field-row{display:flex;align-items:center;justify-content:space-between}.bi-config-field-row>label{margin-bottom:0}.bi-config-type-badge{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;background:#f1f5f9;border-radius:6px;font-size:.82rem;font-weight:500;color:#475569}.bi-config-size-row{display:flex;align-items:center;gap:8px}.bi-config-size-row select{width:auto;flex:1}.bi-config-size-sep{color:#94a3b8;font-size:.8rem}.bi-config-chart-types{display:flex;flex-wrap:wrap;gap:4px}.bi-config-chart-type-btn{padding:5px 10px;border:1px solid #e2e8f0;border-radius:6px;background:#fff;font-size:.78rem;cursor:pointer;color:#64748b;transition:all .15s}.bi-config-chart-type-btn:hover{border-color:#2563eb;color:#2563eb}.bi-config-chart-type-btn.active{background:#2563eb;color:#fff;border-color:#2563eb}.bi-config-toggle{position:relative;display:inline-block;width:36px;height:20px;cursor:pointer;flex-shrink:0}.bi-config-toggle input{opacity:0;width:0;height:0}.bi-config-toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:#cbd5e1;border-radius:20px;transition:background .2s}.bi-config-toggle-slider:before{content:"";position:absolute;height:16px;width:16px;left:2px;bottom:2px;background:#fff;border-radius:50%;transition:transform .2s}.bi-config-toggle input:checked+.bi-config-toggle-slider{background:#2563eb}.bi-config-toggle input:checked+.bi-config-toggle-slider:before{transform:translate(16px)}.bi-config-color-row{display:flex;align-items:center;gap:8px}.bi-config-color-row input[type=color]{width:32px;height:32px;border:2px solid #e2e8f0;border-radius:6px;padding:2px;cursor:pointer;background:none}.bi-config-color-label{font-size:.78rem;color:#64748b;font-family:monospace}.bi-config-actions-section{padding:16px;display:flex;gap:8px;margin-top:auto;border-top:1px solid #f1f5f9}.bi-config-action-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border:1px solid #e2e8f0;border-radius:6px;background:#fff;font-size:.8rem;color:#475569;cursor:pointer;transition:all .15s;flex:1;justify-content:center}.bi-config-action-btn:hover{border-color:#2563eb;color:#2563eb;background:#eff6ff}.bi-config-action-danger{color:#dc2626;border-color:#fecaca}.bi-config-action-danger:hover{background:#fef2f2;border-color:#dc2626;color:#dc2626}.bi-query-config{margin-top:0;padding-top:0;border-top:none}.bi-query-config h4{margin:0 0 12px;font-size:.82rem;font-weight:600;color:#475569}.bi-query-config select{width:100%;padding:7px 10px;border:1px solid #e2e8f0;border-radius:6px;font-size:.85rem}.bi-query-loading{font-size:.8rem;color:#94a3b8;margin:8px 0}.bi-query-actions{display:flex;gap:8px;margin-top:12px}.bi-query-preview{margin-top:8px;font-size:.75rem;color:#94a3b8}.bi-query-preview pre{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bi-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:48px;color:#64748b}.bi-error{padding:12px 16px;margin:12px;background:#fef2f2;color:#dc2626;border-radius:8px;font-size:.875rem;border:1px solid #fecaca}.bi-page-root{display:flex;flex-direction:column;height:100vh;background:#f0f2f5;overflow:hidden}.bi-page-topbar{display:flex;align-items:center;gap:12px;padding:0 20px;height:56px;background:#fff;border-bottom:1px solid #e2e8f0;flex-shrink:0;z-index:10}.bi-page-topbar-left{display:flex;flex-direction:column;gap:1px;min-width:0;flex:1}.bi-page-topbar-title{display:inline-flex;align-items:center;gap:8px;font-size:1.05rem;font-weight:700;color:#0f172a;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bi-page-topbar-right{display:flex;align-items:center;gap:6px;flex-shrink:0}.bi-topbar-action-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border:1px solid #e2e8f0;border-radius:8px;background:#fff;font-size:.82rem;font-weight:500;cursor:pointer;color:#475569;transition:all .15s;white-space:nowrap}.bi-topbar-action-btn:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1;color:#1e293b}.bi-topbar-action-btn:disabled{opacity:.4;cursor:not-allowed}.bi-topbar-action-primary{background:#2563eb;border-color:#2563eb;color:#fff}.bi-topbar-action-primary:hover:not(:disabled){background:#1d4ed8;border-color:#1d4ed8;color:#fff}.bi-topbar-action-ghost{border-color:transparent;background:transparent;color:#64748b}.bi-topbar-action-ghost:hover{background:#f1f5f9;color:#475569}.bi-page-content{flex:1;overflow:auto}.bi-page-body{padding:24px}.bi-page-hint{color:#64748b;font-size:.9rem;margin:0 0 20px}.bi-ds-card-inactive{opacity:.6}.bi-badge-inativo{display:inline-flex;align-items:center;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;padding:2px 8px;border-radius:10px;background:var(--bi-danger-light);color:var(--bi-danger)}.bi-ds-form{max-width:600px;margin:24px auto;display:flex;flex-direction:column;gap:20px;padding:0 20px}.bi-ds-form-group{display:flex;flex-direction:column;gap:6px}.bi-ds-form-group label{font-size:.82rem;font-weight:600;color:var(--bi-text)}.bi-ds-form-group input,.bi-ds-form-group textarea,.bi-ds-form-group select{padding:10px 12px;border:1px solid var(--bi-border);border-radius:var(--bi-radius-xs);font-size:.9rem;color:var(--bi-text);background:#fff;transition:border-color var(--bi-transition)}.bi-ds-form-group input:focus,.bi-ds-form-group textarea:focus,.bi-ds-form-group select:focus{outline:none;border-color:var(--bi-primary);box-shadow:0 0 0 3px #2563eb1a}.bi-ds-form-group small{font-size:.78rem;color:var(--bi-text-muted)}.bi-ds-form-toggle{flex-direction:row;align-items:center;gap:12px}.bi-toggle-btn{display:inline-flex;align-items:center;gap:6px;border:none;background:none;cursor:pointer;font-size:.85rem;color:var(--bi-text-muted);padding:4px 0}.bi-toggle-btn.active{color:var(--bi-success)}.bi-ds-detail{padding:20px;display:flex;flex-direction:column;gap:20px}.bi-ds-detail-desc{color:var(--bi-text-secondary);font-size:.9rem;margin:0;padding:12px 16px;background:var(--bi-primary-light);border-radius:var(--bi-radius-sm)}.bi-ds-campo-form{background:var(--bi-card-bg);border:1px solid var(--bi-primary);border-radius:var(--bi-radius);padding:20px;box-shadow:0 0 0 3px #2563eb14}.bi-ds-campo-form h4{margin:0 0 16px;font-size:.95rem;color:var(--bi-primary)}.bi-ds-campo-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.bi-ds-campo-toggles{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap}.bi-ds-chip{padding:6px 14px;border-radius:20px;border:1px solid var(--bi-border);background:#fff;font-size:.8rem;cursor:pointer;transition:all var(--bi-transition);color:var(--bi-text-secondary)}.bi-ds-chip.active{background:var(--bi-primary);color:#fff;border-color:var(--bi-primary)}.bi-ds-chip:hover{border-color:var(--bi-primary)}.bi-ds-campo-form-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}.bi-ds-campos-section{background:var(--bi-card-bg);border:1px solid var(--bi-card-border);border-radius:var(--bi-radius);padding:20px}.bi-ds-campos-section h4{display:flex;align-items:center;gap:8px;margin:0 0 16px;font-size:.95rem;color:var(--bi-text)}.bi-ds-empty-campos{color:var(--bi-text-muted);font-size:.88rem;text-align:center;padding:24px 0}.bi-ds-campos-table-wrap{overflow-x:auto}.bi-ds-campos-table{width:100%;border-collapse:collapse;font-size:.85rem}.bi-ds-campos-table th{text-align:left;padding:8px 10px;border-bottom:2px solid var(--bi-border);color:var(--bi-text-secondary);font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}.bi-ds-campos-table td{padding:8px 10px;border-bottom:1px solid #f1f5f9;vertical-align:middle}.bi-ds-campos-table tbody tr:hover{background:#f8fafc}.bi-ds-td-ordem{color:var(--bi-text-muted);width:40px;text-align:center}.bi-ds-td-nome code{font-size:.83rem;background:#f1f5f9;padding:2px 6px;border-radius:4px;color:var(--bi-text)}.bi-ds-td-sql{max-width:180px}.bi-ds-td-sql code{font-size:.78rem;background:#f1f5f9;padding:2px 6px;border-radius:4px;color:var(--bi-text-secondary);word-break:break-all}.bi-ds-td-bool{text-align:center;width:60px;color:var(--bi-success);font-weight:600}.bi-ds-td-actions{width:70px;white-space:nowrap}.bi-ds-muted{color:var(--bi-text-muted)}.bi-ds-type-badge{display:inline-block;font-size:.75rem;padding:2px 8px;border-radius:10px;background:#f1f5f9;color:var(--bi-text-secondary);font-weight:500}.bi-btn-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:none;border-radius:var(--bi-radius-xs);cursor:pointer;color:var(--bi-text-secondary);transition:all var(--bi-transition)}.bi-btn-icon:hover{background:#f1f5f9;color:var(--bi-primary)}.bi-btn-icon-danger:hover{background:var(--bi-danger-light);color:var(--bi-danger)}.bi-dashboard-filters-bar{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.bi-dashboard-filters-bar .bi-global-filters{flex:1}.bi-period-filter{position:relative}.bi-period-trigger{display:inline-flex;align-items:center;gap:8px;padding:7px 14px;border:1px solid var(--bi-border);border-radius:var(--bi-radius-sm);background:var(--bi-card-bg);color:var(--bi-text-secondary);font-size:.84rem;cursor:pointer;transition:all var(--bi-transition);white-space:nowrap}.bi-period-trigger:hover{border-color:var(--bi-primary);color:var(--bi-text)}.bi-period-trigger.active{border-color:var(--bi-primary);background:var(--bi-primary-light);color:var(--bi-primary)}.bi-period-trigger-label{font-weight:600}.bi-period-trigger-range{font-weight:400;opacity:.7;font-size:.78rem}.bi-period-chevron{transition:transform var(--bi-transition)}.bi-period-chevron.open{transform:rotate(180deg)}.bi-period-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99}.bi-period-dropdown{position:absolute;top:calc(100% + 4px);left:0;z-index:100;min-width:280px;background:var(--bi-card-bg);border:1px solid var(--bi-border);border-radius:var(--bi-radius);box-shadow:0 8px 30px #0000001f;padding:6px;display:flex;flex-direction:column;gap:2px}.bi-period-option{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border:none;background:none;border-radius:var(--bi-radius-xs);cursor:pointer;font-size:.84rem;color:var(--bi-text);text-align:left;transition:all var(--bi-transition)}.bi-period-option:hover{background:#f1f5f9}.bi-period-option.active{background:var(--bi-primary-light);color:var(--bi-primary);font-weight:600}.bi-period-option-range{font-size:.75rem;color:var(--bi-text-muted);font-weight:400}.bi-period-custom{padding:12px;border-top:1px solid var(--bi-border);display:flex;flex-direction:column;gap:10px}.bi-period-custom-field{display:flex;flex-direction:column;gap:4px}.bi-period-custom-field label{font-size:.78rem;font-weight:600;color:var(--bi-text-secondary)}.bi-period-custom-field input{padding:7px 10px;border:1px solid var(--bi-border);border-radius:var(--bi-radius-xs);font-size:.84rem}.bi-period-custom-field input:focus{outline:none;border-color:var(--bi-primary);box-shadow:0 0 0 3px #2563eb1a}.bi-create-modal{background:var(--bi-card-bg);border-radius:var(--bi-radius);box-shadow:0 20px 60px #00000026;padding:24px;width:440px;max-width:90vw;max-height:80vh;overflow-y:auto}.bi-create-modal h4{margin:0 0 20px;font-size:1.1rem;color:var(--bi-text)}.bi-create-modal-loading{display:flex;align-items:center;gap:8px;padding:16px 0;color:var(--bi-text-muted);font-size:.85rem}.bi-create-modal-origem{margin-top:16px}.bi-create-modal-origem>label{font-size:.82rem;font-weight:600;color:var(--bi-text);display:block;margin-bottom:8px}.bi-origem-tabs{display:flex;gap:0;border:1px solid var(--bi-border);border-radius:var(--bi-radius-sm);overflow:hidden}.bi-origem-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 14px;border:none;background:#fff;color:var(--bi-text-secondary);font-size:.85rem;font-weight:500;cursor:pointer;transition:all var(--bi-transition)}.bi-origem-tab:not(:last-child){border-right:1px solid var(--bi-border)}.bi-origem-tab:hover:not(.active):not(:disabled){background:#f8f9fb}.bi-origem-tab.active{background:var(--bi-primary);color:#fff}.bi-origem-tab:disabled{opacity:.5;cursor:not-allowed}.bi-create-modal-modelos{margin-top:12px}.bi-modelo-search{margin-bottom:8px}.bi-modelo-search input{width:100%;padding:8px 12px;border:1px solid var(--bi-border);border-radius:var(--bi-radius-xs);font-size:.83rem;outline:none;transition:border-color var(--bi-transition);box-sizing:border-box}.bi-modelo-search input:focus{border-color:var(--bi-primary)}.bi-modelo-list{display:flex;flex-direction:column;gap:4px;max-height:220px;overflow-y:auto;border:1px solid var(--bi-border);border-radius:var(--bi-radius-sm);padding:4px}.bi-modelo-option{display:flex;align-items:center;gap:10px;padding:8px 10px;border:none;border-radius:var(--bi-radius-xs);background:transparent;cursor:pointer;text-align:left;transition:all var(--bi-transition)}.bi-modelo-option:hover{background:#f1f5f9}.bi-modelo-option.active{background:var(--bi-primary-light)}.bi-modelo-radio{width:16px;height:16px;border-radius:50%;border:2px solid var(--bi-border);flex-shrink:0;transition:all var(--bi-transition);position:relative}.bi-modelo-radio.checked{border-color:var(--bi-primary)}.bi-modelo-radio.checked:after{content:"";position:absolute;top:3px;left:3px;width:6px;height:6px;border-radius:50%;background:var(--bi-primary)}.bi-modelo-info{flex:1;min-width:0}.bi-modelo-info span{font-size:.85rem;color:var(--bi-text);font-weight:500;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bi-modelo-info small{display:block;font-size:.73rem;color:var(--bi-text-muted);margin-top:1px}.bi-modelo-empty{padding:16px;text-align:center;color:var(--bi-text-muted);font-size:.83rem}.bi-badge-modelo{display:inline-flex;align-items:center;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;padding:2px 8px;border-radius:10px;background:#f0f0ff;color:#6d28d9}.bi-config-toggle-row{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.85rem}.bi-config-toggle-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--bi-primary)}.dashboard-with-sidebar{margin-left:64px;transition:margin-left .25s cubic-bezier(.4,0,.2,1);min-height:100vh;background-color:transparent}.dashboard-with-sidebar.sidebar-expanded,.sidebar.expanded+.dashboard-with-sidebar{margin-left:240px}.dashboard-main{flex:1;max-width:1400px;padding:28px 32px;width:100%}.modules-container{animation:fadeIn .4s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modules-toolbar{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:24px}.modules-welcome{flex-shrink:0}.modules-welcome h2{font-size:28px;font-weight:800;color:var(--text-primary);margin-bottom:4px;letter-spacing:-.5px}.modules-welcome p{font-size:14px;color:var(--text-secondary)}.modules-search{position:relative;width:300px;flex-shrink:0}.modules-search .search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-tertiary);pointer-events:none}.search-input{width:100%;padding:10px 14px 10px 42px;border:1px solid var(--border);border-radius:10px;font-size:14px;color:var(--text-primary);background:var(--input-bg);outline:none;transition:all .2s ease}.search-input::placeholder{color:var(--text-tertiary)}.search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.modules-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:18px}.modules-status{grid-column:1 / -1;text-align:center;padding:40px 20px;color:var(--text-secondary);font-size:15px}@media (max-width: 768px){.dashboard-with-sidebar,.dashboard-with-sidebar.sidebar-expanded{margin-left:0}.dashboard-main{padding:20px 16px}.modules-toolbar{flex-direction:column;align-items:stretch;gap:16px}.modules-welcome h2{font-size:22px}.modules-search{width:100%}.modules-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}}.db-config-page{min-height:100vh;background:#f5f7fa}.db-config-header{display:flex;align-items:center;gap:12px;padding:16px 24px;background:#fff;border-bottom:1px solid #e2e8f0}.db-config-header h2{margin:0;font-size:1.1rem;font-weight:600;color:#1e293b}.db-config-back{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:#f1f5f9;border-radius:8px;cursor:pointer;color:#475569;transition:background .2s}.db-config-back:hover{background:#e2e8f0}.db-config-content{max-width:560px;margin:32px auto;padding:0 24px}.db-config-loading{display:flex;flex-direction:column;align-items:center;gap:12px;padding:48px 0;color:#94a3b8}.db-config-form{background:#fff;border-radius:12px;border:1px solid #e2e8f0;padding:28px;display:flex;flex-direction:column;gap:18px}.db-config-row{display:flex;gap:14px}.db-config-field{display:flex;flex-direction:column;gap:6px;flex:1}.db-config-field-lg{flex:2}.db-config-field-sm{flex:0 0 100px}.db-config-field label{font-size:.82rem;font-weight:600;color:#475569}.db-config-field input{padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:.9rem;color:#1e293b;outline:none;transition:border-color .2s}.db-config-field input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.db-config-result{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:8px;font-size:.85rem}.db-config-result.success{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}.db-config-result.error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.db-config-actions{display:flex;gap:12px;padding-top:4px}.db-config-btn{display:flex;align-items:center;gap:6px;padding:10px 18px;border:none;border-radius:8px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s}.db-config-btn:disabled{opacity:.5;cursor:not-allowed}.db-config-btn-secondary{background:#f1f5f9;color:#475569;border:1px solid #d1d5db}.db-config-btn-secondary:hover:not(:disabled){background:#e2e8f0}.db-config-btn-primary{background:#2563eb;color:#fff}.db-config-btn-primary:hover:not(:disabled){background:#1d4ed8}.db-config-hint{margin:0;font-size:.78rem;color:#94a3b8;line-height:1.4}.db-setup-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#1e293b,#0f172a);padding:20px}.db-setup-box{background:#fff;border-radius:12px;box-shadow:0 25px 80px #0000004d;padding:40px;width:100%;max-width:600px;animation:slideIn .5s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.db-setup-header{text-align:center;margin-bottom:40px}.db-setup-header svg{color:var(--primary);margin-bottom:16px;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.db-setup-header h1{font-size:26px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.db-setup-header p{color:var(--text-secondary);font-size:14px}.db-setup-form{margin-bottom:30px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.form-group{display:flex;flex-direction:column}.form-group.full-width{grid-column:1 / -1}.form-group label{font-weight:600;color:var(--text-primary);margin-bottom:8px;font-size:14px}.form-group input{padding:12px 14px;border:1px solid var(--border);border-radius:8px;font-size:14px;transition:var(--transition);background-color:var(--bg-primary);font-family:Courier New,monospace}.form-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.form-group input:disabled{background-color:var(--bg-tertiary);cursor:not-allowed;opacity:.6}.status-message{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:8px;font-size:14px;margin-bottom:16px;animation:slideIn .3s ease-out}.status-message.success{background-color:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}.status-message.error{background-color:#fef2f2;color:#7f1d1d;border:1px solid #fecaca}.status-message.loading{background-color:#eff6ff;color:#0c4a6e;border:1px solid #bfdbfe}.status-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0}.status-icon .spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.form-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:24px}.btn{padding:12px 16px;border:none;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center;gap:8px}.btn-primary{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;box-shadow:0 4px 12px #2563eb4d}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #2563eb66}.btn-secondary{background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background-color:#e0e7ff;border-color:var(--primary);color:var(--primary)}.btn:disabled{opacity:.5;cursor:not-allowed}.db-setup-info{background-color:var(--bg-secondary);border-left:4px solid var(--primary);padding:16px;border-radius:8px}.db-setup-info h3{font-size:14px;font-weight:700;color:var(--text-primary);margin-bottom:12px}.db-setup-info ul{list-style:none;padding:0;margin:0}.db-setup-info li{font-size:13px;color:var(--text-secondary);margin-bottom:8px;line-height:1.5}.db-setup-info li:last-child{margin-bottom:0}.db-setup-info strong{color:var(--text-primary);font-weight:600}@media (max-width: 640px){.db-setup-box{padding:24px}.form-row{grid-template-columns:1fr;gap:12px}.form-actions{grid-template-columns:1fr;gap:10px}.db-setup-header h1{font-size:22px}}:root{--primary: #3b82f6;--primary-dark: #2563eb;--primary-light: #eff6ff;--primary-glow: rgba(59, 130, 246, .4);--success: #10b981;--success-bg: #ecfdf5;--success-border: #a7f3d0;--danger: #ef4444;--danger-bg: #fef2f2;--danger-border: #fca5a5;--warning: #f59e0b;--bg-app: #f4f4f5;--bg-sidebar: #0f172a;--bg-tertiary: #e4e4e7;--surface-main: #ffffff;--surface-hover: #fafafa;--input-bg: #ffffff;--input-bg-focus: #ffffff;--input-bg-disabled: #f4f4f5;--text-primary: #18181b;--text-secondary: #52525b;--text-tertiary: #a1a1aa;--text-inverse: #ffffff;--border: #e4e4e7;--border-input: #d4d4d8;--border-input-hover: #a1a1aa;--border-focus: rgba(59, 130, 246, .3);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .05), 0 2px 4px -2px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .05), 0 4px 6px -4px rgba(0, 0, 0, .05);--form-shadow: 0 8px 30px rgba(0, 0, 0, .04), 0 1px 3px rgba(0, 0, 0, .02);--header-shadow: 0 4px 20px rgba(0, 0, 0, .03);--transition: all .3s cubic-bezier(.4, 0, .2, 1);color-scheme:light}[data-theme=dark]{--primary: #3b82f6;--primary-dark: #60a5fa;--primary-light: rgba(59, 130, 246, .15);--primary-glow: rgba(59, 130, 246, .4);--bg-app: #030712;--bg-sidebar: #030712;--bg-tertiary: #1f2937;--surface-main: #111827;--surface-hover: #1f2937;--input-bg: rgba(0, 0, 0, .2);--input-bg-focus: #111827;--input-bg-disabled: #111827;--text-primary: #f9fafb;--text-secondary: #9ca3af;--text-tertiary: #6b7280;--text-inverse: #030712;--border: #374151;--border-input: #4b5563;--border-input-hover: #6b7280;--border-focus: rgba(59, 130, 246, .5);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .5);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .5);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5);--form-shadow: 0 20px 40px rgba(0, 0, 0, .6), 0 1px 3px rgba(0, 0, 0, .4);--header-shadow: 0 4px 20px rgba(0, 0, 0, .4);color-scheme:dark}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-app);color:var(--text-primary)}html,body,#root{width:100%;height:100%}
