:root{--bg-primary:#0f0f1a;--bg-secondary:#1a1a2e;--bg-tertiary:#252538;--bg-hover:#2d2d42;--text-primary:#e4e4e7;--text-secondary:#a1a1aa;--text-muted:#71717a;--accent-primary:#6366f1bf;--accent-hover:#4f46e5;--accent-light:#818cf8;--success:#10b981;--success-color:#10b981;--success-rgb:16,185,129;--error:#ef4444;--error-color:#ef4444;--warning:#f59e0b;--info:#3b82f6;--border-color:#3f3f46;--shadow:0 4px 6px -1px rgba(0,0,0,.3);--shadow-lg:0 10px 15px -3px rgba(0,0,0,.5);--transition:all 0.3s cubic-bezier(0.4,0,0.2,1)}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-y:scroll}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh}@keyframes slideIn{0%{transform:scaleX(0)}to{transform:scaleX(1)}}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-10px)}75%{transform:translateX(10px)}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px;border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:var(--border-color);border:2px solid transparent;background-clip:padding-box}*{scrollbar-width:thin;scrollbar-color:var(--bg-tertiary) transparent}.modal-content::-webkit-scrollbar-track{background:transparent;margin:16px 0}.modal-content::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px;border:2px solid transparent;background-clip:padding-box}.modal-content::-webkit-scrollbar-thumb:hover{background:var(--border-color);border:2px solid transparent;background-clip:padding-box}*{scrollbar-width:none!important;-ms-overflow-style:none!important}::-webkit-scrollbar-button{display:none!important;width:0!important;height:0!important}::-webkit-scrollbar-corner{background:transparent!important}.btn{padding:12px 24px;border:none;border-radius:8px;font-size:1rem;cursor:pointer;transition:var(--transition);font-weight:500;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn-primary{background:var(--accent-primary);color:#fff;width:100%;position:relative}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:var(--shadow)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.7;cursor:not-allowed;transform:none}.btn-primary i{font-size:1rem}.btn-primary .btn-loader{display:flex;align-items:center;gap:8px}.btn-primary .btn-loader i{animation:spin 1s linear infinite}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-hover)}.btn-filter{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);position:relative}.btn-filter:hover{background:var(--bg-hover);border-color:var(--accent-primary)}.filter-count{position:absolute;top:-8px;right:-8px;background:var(--accent-primary);color:#fff;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700}.btn-refresh{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);padding:8px 16px;font-size:.9rem}.btn-refresh:hover{background:var(--bg-hover)}.btn-pagination{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);padding:8px 16px}.btn-pagination:disabled{opacity:.5;cursor:not-allowed}.btn-pagination:not(:disabled):hover{background:var(--bg-hover);border-color:var(--accent-primary)}.error-message{margin-top:15px;padding:12px;background:rgba(239,68,68,.1);border:1px solid var(--error);border-radius:8px;color:var(--error);font-size:.9rem;display:none}.error-message.show{display:block;animation:shake .5s ease-out}.success-message{margin-top:15px;padding:12px;background:rgba(16,185,129,.1);border:1px solid var(--success);border-radius:8px;color:var(--success);font-size:.9rem;display:none}.success-message.show{display:block;animation:fadeIn .3s ease-out}.copy-notification{position:fixed;bottom:30px;left:50%;transform:translateX(-50%) translateY(100px);background:var(--success);color:#fff;padding:12px 24px;border-radius:8px;font-weight:500;box-shadow:var(--shadow-lg);z-index:10000;opacity:0;transition:all .3s ease-out}.copy-notification.show{transform:translateX(-50%) translateY(0);opacity:1}.custom-checkbox{position:relative;display:flex;align-items:center;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;gap:.75rem}.custom-checkbox input[type=checkbox]{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.custom-checkbox .checkmark{position:relative;height:22px;width:22px;background:var(--surface-light,#2d2d42);border:2px solid var(--border-color,#3f3f46);border-radius:6px;transition:all .3s ease;flex-shrink:0;display:flex;align-items:center;justify-content:center}.custom-checkbox:hover .checkmark{border-color:var(--primary-color,#6366f1);background:rgba(99,102,241,.05)}.custom-checkbox input:checked~.checkmark{background:linear-gradient(135deg,var(--primary-color,#6366f1),#818cf8);border-color:var(--primary-color,#6366f1)}.custom-checkbox .checkmark:after{content:"";position:absolute;display:none;left:6px;top:2px;width:5px;height:10px;border:solid #fff;border-width:0 2.5px 2.5px 0;transform:rotate(45deg)}.custom-checkbox input:checked~.checkmark:after{display:block;animation:checkmark-appear .3s ease}@keyframes checkmark-appear{0%{transform:rotate(45deg) scale(0);opacity:0}50%{transform:rotate(45deg) scale(1.2)}to{transform:rotate(45deg) scale(1);opacity:1}}.custom-checkbox input:focus~.checkmark{outline:2px solid var(--primary-color,#6366f1);outline-offset:2px}.custom-checkbox input:disabled~.checkmark{opacity:.5;cursor:not-allowed;background:var(--surface-dark,#252538)}.custom-checkbox input:disabled~.checkbox-label{opacity:.5;cursor:not-allowed}.custom-checkbox.disabled{cursor:not-allowed}.checkbox-label{font-size:.9375rem;color:var(--text-primary,#e4e4e7);transition:color .2s ease;display:inline-flex;align-items:center;gap:.5rem;line-height:1.5;flex:1 1}.custom-checkbox:hover .checkbox-label{color:var(--primary-color,#6366f1)}.custom-checkbox input:checked~.checkbox-label{color:var(--text-primary,#e4e4e7);font-weight:500}.custom-checkbox.small .checkmark{height:18px;width:18px}.custom-checkbox.small .checkmark:after{left:5px;top:1px;width:4px;height:8px;border-width:0 2px 2px 0}.custom-checkbox.small .checkbox-label{font-size:.875rem}.custom-checkbox.large .checkmark{height:26px;width:26px}.custom-checkbox.large .checkmark:after{left:8px;top:3px;width:6px;height:12px;border-width:0 3px 3px 0}.custom-checkbox.large .checkbox-label{font-size:1rem}.permission-item .custom-checkbox{width:100%;height:100%;min-height:54px;padding:.75rem;background:var(--surface-light,#2d2d42);border:1px solid var(--border-color,#3f3f46);border-radius:8px;transition:all .2s ease;display:flex;align-items:center}.permission-item .custom-checkbox:hover{background:rgba(99,102,241,.05);border-color:var(--primary-color,#6366f1);transform:translateY(-1px)}.permission-item .custom-checkbox input:checked{background:rgba(99,102,241,.1)}.permission-item .custom-checkbox .checkbox-label{flex:1 1;word-break:break-word;line-height:1.4}.filter-option .custom-checkbox{padding:.5rem;width:100%}.log-type-access-item .custom-checkbox,.log-type-checkbox-item .custom-checkbox,.role-checkbox-item .custom-checkbox{display:flex!important;flex-direction:row!important;align-items:center!important;width:100%;padding:.625rem .75rem;background:var(--surface-light,#2d2d42);border:1px solid var(--border-color,#3f3f46);border-radius:6px;transition:all .2s ease}.log-type-access-item .custom-checkbox:hover,.log-type-checkbox-item .custom-checkbox:hover,.role-checkbox-item .custom-checkbox:hover{background:rgba(99,102,241,.05);border-color:var(--primary-color,#6366f1)}.log-type-access-item .custom-checkbox .checkbox-label,.log-type-checkbox-item .custom-checkbox .checkbox-label,.role-checkbox-item .custom-checkbox .checkbox-label{display:flex;flex-direction:row;align-items:center;gap:.5rem;width:100%;flex:1 1}.log-type-access-item .custom-checkbox .checkmark,.log-type-checkbox-item .custom-checkbox .checkmark,.role-checkbox-item .custom-checkbox .checkmark{order:-1;flex-shrink:0}.custom-checkbox .log-type-color-dot{flex-shrink:0;display:inline-block;width:12px;height:12px;border-radius:50%;vertical-align:middle}.log-types-access,.roles-checkboxes{max-height:300px;overflow-y:auto}.log-type-access-item,.log-type-checkbox-item,.role-checkbox-item{margin-bottom:0}.log-type-access-item:not(:last-child),.log-type-checkbox-item:not(:last-child),.role-checkbox-item:not(:last-child){margin-bottom:.5rem}.confirm-checkbox-container .custom-checkbox{padding:.75rem;background:rgba(239,68,68,.05);border:1px solid rgba(239,68,68,.3);border-radius:8px}.confirm-checkbox-container .custom-checkbox:hover{background:rgba(239,68,68,.1);border-color:var(--danger-color,#ef4444)}.confirm-checkbox-container .custom-checkbox input:checked~.checkmark{background:linear-gradient(135deg,var(--danger-color,#ef4444),#f87171);border-color:var(--danger-color,#ef4444)}@media (max-width:768px){.custom-checkbox{gap:.625rem}.custom-checkbox .checkmark{height:20px;width:20px}.custom-checkbox .checkmark:after{left:5px;top:1px;width:4px;height:9px}.checkbox-label{font-size:.875rem}.log-type-checkbox-item .custom-checkbox,.role-checkbox-item .custom-checkbox{padding:.5rem}}@media (max-width:480px){.log-type-checkbox-item .custom-checkbox,.permission-item .custom-checkbox,.role-checkbox-item .custom-checkbox{padding:.625rem}}.custom-checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.custom-checkbox-input{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.custom-checkbox-box{position:relative;width:22px;height:22px;background:var(--surface-light,#2d2d42);border:2px solid var(--border-color,#3f3f46);border-radius:6px;transition:all .3s ease;flex-shrink:0;display:flex;align-items:center;justify-content:center}.custom-checkbox-box i{font-size:.75rem;color:#fff;opacity:0;transform:scale(0);transition:all .3s ease}.custom-checkbox-label:hover .custom-checkbox-box{border-color:var(--primary-color,#6366f1);background:rgba(99,102,241,.05)}.custom-checkbox-input:checked~.custom-checkbox-box{background:linear-gradient(135deg,var(--primary-color,#6366f1),#818cf8);border-color:var(--primary-color,#6366f1)}.custom-checkbox-input:checked~.custom-checkbox-box i{opacity:1;transform:scale(1)}.custom-checkbox-input:focus~.custom-checkbox-box{outline:2px solid var(--primary-color,#6366f1);outline-offset:2px}.custom-checkbox-input:disabled~.custom-checkbox-box{opacity:.5;cursor:not-allowed;background:var(--surface-dark,#252538)}.custom-checkbox-input:disabled~.custom-checkbox-text{opacity:.5;cursor:not-allowed}.custom-checkbox-text{color:var(--text-primary,#e4e4e7);font-size:.9375rem}.custom-select-wrapper{width:100%}.custom-select{width:100%;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;display:block}.custom-select-trigger{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:.9375rem;transition:all .2s ease;min-height:44px;cursor:pointer}.custom-select-trigger:hover{border-color:var(--accent-primary);background:var(--bg-hover)}.custom-select-trigger .select-value{flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.custom-select-trigger .select-value.placeholder{color:var(--text-secondary);opacity:.7}.custom-select-trigger .select-arrow{font-size:.75rem;color:var(--text-secondary);transition:transform .2s ease;flex-shrink:0;display:flex;align-items:center;justify-content:center;width:1rem;height:1rem}.custom-select-trigger .select-arrow.open{transform:rotate(180deg)}.custom-select-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--bg-secondary);border:1px solid var(--accent-primary);border-top:none;border-bottom-left-radius:8px;border-bottom-right-radius:8px;max-height:250px;overflow-y:auto;box-shadow:0 4px 12px rgba(0,0,0,.3)}.custom-select-dropdown.dropdown-up{top:auto;bottom:100%;border-top:1px solid var(--accent-primary);border-bottom:none;border-top-left-radius:8px;border-top-right-radius:8px;border-bottom-left-radius:0;border-bottom-right-radius:0;box-shadow:0 -4px 12px rgba(0,0,0,.3)}.custom-select.open .custom-select-trigger{border-color:var(--accent-primary)}.custom-select.open:has(.dropdown-up) .custom-select-trigger{border-top-left-radius:0;border-top-right-radius:0;border-bottom-left-radius:8px;border-bottom-right-radius:8px}.custom-select.open:not(:has(.dropdown-up)) .custom-select-trigger{border-bottom-left-radius:0;border-bottom-right-radius:0}.custom-select-option{padding:.75rem 1rem;color:var(--text-primary);font-size:.9375rem;cursor:pointer;transition:all .15s ease;border-bottom:1px solid var(--border-color)}.custom-select-option:last-child{border-bottom:none}.custom-select-option:hover{background:var(--bg-hover);color:var(--accent-primary)}.custom-select-option.selected{background:rgba(99,102,241,.1);color:var(--accent-primary);font-weight:500}.custom-select-option.selected:before{content:"✓ ";margin-right:.5rem}.custom-select-dropdown::-webkit-scrollbar{width:6px}.custom-select-dropdown::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:3px}.custom-select-dropdown::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.custom-select-dropdown::-webkit-scrollbar-thumb:hover{background:var(--accent-primary)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.custom-select-dropdown:not(.dropdown-up){animation:slideDown .2s ease}.custom-select-dropdown.dropdown-up{animation:slideUp .2s ease}.custom-select-wrapper.small .custom-select-trigger{padding:.5rem .75rem;font-size:.875rem;min-height:36px}.custom-select-wrapper.small .custom-select-option{padding:.5rem .75rem;font-size:.875rem}.custom-select-wrapper.disabled{opacity:.5;pointer-events:none}.custom-select-wrapper.disabled .custom-select-trigger{cursor:not-allowed;background:var(--bg-tertiary)}.custom-select,.custom-select-wrapper{display:block;width:100%}.custom-select-trigger{width:100%;box-sizing:border-box}.custom-select-trigger .select-arrow,.custom-select-trigger>*{pointer-events:none}.custom-select,.custom-select-wrapper{position:relative;min-height:44px}.custom-select-trigger{position:absolute!important;inset:0!important;display:flex!important;align-items:center!important;gap:.75rem!important;padding:.75rem 1rem!important;box-sizing:border-box!important;z-index:2!important;background:var(--bg-secondary)!important}.custom-select-dropdown{z-index:1050}.icon-picker-container{position:relative;width:100%}.icon-picker-container .form-label{display:block;font-size:.875rem;font-weight:500;color:var(--text-primary);margin-bottom:.5rem}.icon-picker-trigger{display:flex;align-items:center;gap:.75rem;width:100%;padding:.625rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:.9375rem;cursor:pointer;transition:all .2s ease}.icon-picker-trigger:hover{border-color:var(--primary-color);background:var(--background-light)}.icon-picker-trigger:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(52,152,219,.1)}.icon-picker-trigger>i:first-child{font-size:1.125rem;color:var(--primary-color);flex-shrink:0}.icon-picker-trigger>span{flex:1 1;text-align:left}.icon-picker-trigger .chevron-icon{font-size:.75rem;color:var(--text-secondary);transition:transform .2s ease;flex-shrink:0}.icon-picker-overlay{position:absolute;top:calc(100% + .5rem);left:0;right:0;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.15);z-index:1000;max-height:300px;overflow-y:auto;animation:fadeIn .15s ease}.icon-picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(42px,1fr));grid-gap:.375rem;gap:.375rem;padding:.75rem}.icon-picker-grid .icon-option{width:42px;height:42px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border:2px solid transparent;border-radius:6px;cursor:pointer;transition:all .2s ease;font-size:1.125rem;color:var(--text-primary)}.icon-picker-grid .icon-option:hover{background:var(--background-light);border-color:var(--primary-color);transform:scale(1.05)}.icon-picker-grid .icon-option.selected{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.icon-picker-overlay::-webkit-scrollbar{width:8px}.icon-picker-overlay::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:0 8px 8px 0}.icon-picker-overlay::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.icon-picker-overlay::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.color-picker-trigger>i:first-child{font-size:1.25rem}.color-option{position:relative}.color-option i{font-size:1.5rem;transition:transform .2s ease}.color-option:hover i{transform:scale(1.15)}.color-option.selected:after{content:"\f00c";font-family:Font Awesome\ 5 Free;font-weight:900;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:.875rem;text-shadow:0 0 3px rgba(0,0,0,.5);pointer-events:none}@media (max-width:768px){.icon-picker-overlay{max-height:250px}.icon-picker-grid{grid-template-columns:repeat(auto-fill,minmax(38px,1fr))}.icon-picker-grid .icon-option{width:38px;height:38px;font-size:1rem}.color-option i{font-size:1.25rem}}.auth-container{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:20px;background:linear-gradient(135deg,var(--bg-primary) 0,var(--bg-secondary) 100%)}.auth-box{background:var(--bg-secondary);border-radius:16px;padding:40px;width:100%;max-width:450px;box-shadow:var(--shadow-lg);border:1px solid var(--border-color);animation:slideUp .5s ease-out}.logo{text-align:center;margin-bottom:30px}.logo-icon{width:80px;height:80px;margin:0 auto 20px;background:linear-gradient(135deg,var(--accent-primary),var(--accent-light));border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:2.5rem;color:#fff;box-shadow:var(--shadow-md);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.logo h1{font-size:2rem;margin-bottom:8px;background:linear-gradient(135deg,var(--accent-primary),var(--accent-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.subtitle{color:var(--text-secondary);font-size:.9rem}.auth-tabs{display:flex;gap:10px;margin-bottom:30px;border-bottom:2px solid var(--border-color)}.tab-button{flex:1 1;padding:12px;background:none;border:none;color:var(--text-secondary);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;font-weight:500;display:flex;align-items:center;justify-content:center;gap:8px}.tab-button,.tab-button i{font-size:1rem}.tab-button:hover{color:var(--text-primary)}.tab-button.active{color:var(--accent-primary)}.tab-button.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--accent-primary);animation:expandWidth .4s cubic-bezier(.4,0,.2,1)}@keyframes expandWidth{0%{transform:scaleX(0);opacity:0}to{transform:scaleX(1);opacity:1}}.auth-form{display:none;opacity:0;transform:translateY(20px)}.auth-form.active{display:block;animation:slideInUp .5s cubic-bezier(.4,0,.2,1) forwards}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes slideOutDown{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-20px) scale(.95)}}.input-with-icon{position:relative;display:flex;align-items:center}.input-with-icon .input-icon{position:absolute;left:16px;color:var(--text-muted);pointer-events:none;transition:var(--transition)}.input-with-icon input{width:100%;padding:12px 16px 12px 45px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:1rem;transition:var(--transition)}.input-with-icon input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px rgba(99,102,241,.1)}.input-with-icon input:focus~.input-icon{color:var(--accent-primary)}.input-with-icon .input-icon.match{color:var(--success-color)}.input-with-icon .input-icon.no-match{color:var(--error-color)}.input-with-icon input::placeholder{color:var(--text-muted)}.toggle-password{position:absolute;right:12px;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;transition:var(--transition);border-radius:4px;z-index:2}.toggle-password:hover{color:var(--accent-primary);background:rgba(99,102,241,.1)}.toggle-password i{font-size:1rem}.password-strength{margin-top:8px;opacity:0;transition:opacity .3s ease;height:0;overflow:hidden}.password-strength.visible{opacity:1;height:auto}.strength-bar{height:4px;background:var(--border-color);border-radius:2px;overflow:hidden;margin-bottom:4px}.strength-bar-fill{height:100%;width:0;transition:all .3s ease;border-radius:2px}.strength-bar-fill.weak{width:33%;background:#ef4444}.strength-bar-fill.medium{width:66%;background:#f59e0b}.strength-bar-fill.strong{width:100%;background:#10b981}.strength-text{font-size:.75rem;color:var(--text-muted)}.strength-text.weak{color:var(--error-color)}.strength-text.medium{color:#f59e0b}.strength-text.strong{color:var(--success-color)}.dashboard-container{display:grid;grid-template-columns:280px 1fr;grid-template-rows:70px 1fr;min-height:100vh}.dashboard-header{grid-column:1/-1;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:0 30px;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow);min-height:70px;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.header-left{flex-shrink:1;min-width:0;margin-right:20px}.header-left h1{font-size:1.5rem;background:linear-gradient(135deg,var(--accent-primary),var(--accent-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-right{gap:20px;margin-left:auto}.header-right,.user-panel{display:flex;align-items:center;flex-shrink:0}.user-panel{gap:15px;padding:8px 16px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;transition:var(--transition)}.user-panel:hover{border-color:var(--accent-primary);box-shadow:0 0 0 3px rgba(99,102,241,.1)}.user-info{color:var(--text-primary);font-size:.95rem;display:flex;align-items:center;gap:8px;font-weight:500;line-height:1}.user-info i.fa-user-circle{font-size:1.3rem}.user-info i.fa-circle-notch,.user-info i.fa-user-circle{color:var(--accent-primary);display:flex;align-items:center}.user-info i.fa-circle-notch{font-size:1rem}.user-info span{line-height:1.3rem}.user-actions{gap:6px;padding-left:12px;border-left:1px solid var(--border-color)}.btn-icon,.user-actions{display:flex;align-items:center}.btn-icon{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:8px;border-radius:8px;transition:var(--transition);justify-content:center;font-size:1.1rem}.btn-icon:hover{background:var(--bg-hover);color:var(--accent-primary)}.btn-icon i{transition:transform .3s ease}.btn-icon:hover i.fa-cog{transform:rotate(90deg)}.btn-icon.active{background:var(--accent-primary);color:#fff}.btn-icon.active:hover{background:var(--accent-primary-dark)}.btn-logout{color:var(--text-secondary)}.btn-logout:hover{color:var(--error-color);background:rgba(239,68,68,.1)}.main-content{overflow-y:auto;background:var(--bg-primary);padding:30px}.main-content:has(.message-content){padding:0;overflow:hidden;height:calc(100vh - 70px)}.stats-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));grid-gap:20px;gap:20px;margin-bottom:30px}.stat-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:20px;display:flex;align-items:center;gap:15px;transition:var(--transition)}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--accent-primary)}.stat-icon{font-size:2.5rem}.stat-icon i{color:var(--accent-primary)}.stat-label{color:var(--text-secondary);font-size:.9rem;margin-bottom:4px}.stat-value{font-size:1.8rem;font-weight:700;color:var(--text-primary)}.controls-section{display:flex;gap:15px;margin-bottom:30px}.search-bar{flex:1 1;position:relative}.search-bar input{width:100%;padding:12px 16px 12px 40px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:1rem;transition:var(--transition)}.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-secondary);pointer-events:none}.search-bar input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px rgba(99,102,241,.1)}.loading{text-align:center;padding:40px;font-size:1.1rem}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border-color);padding:20px;overflow-y:auto;transition:all .3s ease;min-width:280px;position:-webkit-sticky;position:sticky;top:70px;height:calc(100vh - 70px);z-index:900}.sidebar h3{margin-bottom:15px;color:var(--text-secondary);font-size:.9rem;text-transform:uppercase;letter-spacing:1px}.projects-list{gap:8px}.project-item,.projects-list{display:flex;flex-direction:column}.project-item{padding:12px 16px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;cursor:pointer;transition:var(--transition);position:relative}.project-item:hover{background:var(--bg-hover);border-color:var(--accent-primary);transform:translateX(4px)}.project-item.active{background:linear-gradient(135deg,#6366f105,#818cf8c7);border-color:var(--accent-primary);color:#fff}.project-name{font-weight:500;margin-bottom:4px}.project-id{font-size:.8rem;color:var(--text-muted)}.project-item.active .project-id{color:hsla(0,0%,100%,.7)}.project-toggle-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:32px;height:32px;border:none;background:hsla(0,0%,100%,.15);color:#fff;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:var(--transition);opacity:0;pointer-events:none}.project-toggle-btn i{font-size:inherit}.project-item.active .project-toggle-btn{opacity:1;pointer-events:auto}.project-toggle-btn:hover{background:hsla(0,0%,100%,.25);transform:translateY(-50%) scale(1.1)}.project-toggle-btn:active{transform:translateY(-50%) scale(.95)}.sidebar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.sidebar-header h3{margin-bottom:0}.sidebar-toggle{width:32px;height:32px;padding:0;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.sidebar-toggle:hover{background:var(--bg-hover);border-color:var(--accent-primary)}.sidebar-toggle i{transition:transform .3s ease}.sidebar.collapsed{min-width:0;width:0;padding:0;border-right:none;overflow:hidden}.sidebar-reopen-btn{position:fixed;left:0;top:50%;transform:translateY(-50%);width:36px;height:80px;background:var(--bg-secondary);border:1px solid var(--border-color);border-left:none;border-radius:0 8px 8px 0;cursor:pointer;z-index:100;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:2px 0 8px rgba(0,0,0,.2)}.sidebar-reopen-btn:hover{background:var(--accent-primary);width:40px}.sidebar-reopen-btn i{color:var(--text-primary)}.sidebar-reopen-btn:hover i{color:#fff}.messaging-item{display:flex;flex-direction:row!important;align-items:center;gap:12px;padding:12px}.messaging-avatar{width:42px;height:42px;min-width:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.1rem;position:relative;flex-shrink:0}.messaging-status-indicator{position:absolute;bottom:0;right:0;width:12px;height:12px;border-radius:50%;border:2px solid var(--bg-tertiary)}.messaging-info{flex:1 1;min-width:0;display:flex;flex-direction:column;gap:2px}.messaging-item .project-name{font-size:.95rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.messaging-item .project-id{font-size:.8rem;color:var(--text-muted);margin-bottom:0}.messaging-status{display:flex;align-items:center;gap:4px}.messaging-members{display:flex;align-items:center;gap:2px}.messaging-member-avatar-tiny{width:18px;height:18px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:.6rem;border:1px solid var(--bg-tertiary)}.messaging-more-members{font-size:.75rem;color:var(--text-muted);margin-left:4px}.messaging-unread-badge{background:var(--accent-danger);color:#fff;font-size:.7rem;padding:2px 6px;border-radius:10px;font-weight:600;min-width:20px;text-align:center;flex-shrink:0}.messaging-item:hover .messaging-unread-badge{background:var(--accent-primary)}.messaging-item.active .messaging-unread-badge{background:#fff;color:var(--accent-primary)}.messaging-item.active .project-id,.messaging-item.active .project-name{color:#fff}.messaging-item.active .project-id{opacity:.9}.sidebar-fixed-header{flex-shrink:0}.sidebar-search{padding:0 0 15px;border-bottom:1px solid var(--border-color);margin-bottom:15px}.sidebar-search .search-input-wrapper{position:relative;display:flex;align-items:center}.sidebar-search .search-input-wrapper i.fa-search{position:absolute;left:12px;color:var(--text-secondary);font-size:.85rem;pointer-events:none}.sidebar-search .search-input{width:100%;padding:10px 40px 10px 38px;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-tertiary);color:var(--text-primary);font-size:.9rem;transition:all .2s}.sidebar-search .search-input:focus{outline:none;border-color:var(--accent-primary);background:var(--bg-primary)}.sidebar-search .search-input::placeholder{color:var(--text-secondary);opacity:.7}.sidebar-search .btn-clear-search{position:absolute;right:8px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:6px;border-radius:6px;transition:all .2s;display:flex;align-items:center;justify-content:center;font-size:.8rem}.sidebar-search .btn-clear-search:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-tabs{display:flex;gap:8px;margin-bottom:15px}.sidebar-tab{flex:1 1;padding:10px 12px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px;font-size:.85rem;font-weight:500;color:var(--text-secondary)}.sidebar-tab i{font-size:.9rem}.sidebar-tab:hover{background:var(--bg-hover);border-color:var(--accent-primary);color:var(--text-primary)}.sidebar-tab.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.empty-state-sidebar{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;color:var(--text-secondary)}.empty-state-sidebar i{font-size:3rem;margin-bottom:12px;opacity:.3;color:var(--accent-primary)}.empty-state-sidebar p{margin:0;font-size:.9rem;opacity:.8}.loading{gap:10px;padding:20px;font-size:.9rem}.loading i.fa-spinner{animation:spin 1s linear infinite}.logs-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:20px}.logs-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid var(--border-color)}.logs-title-container{display:flex;align-items:center;gap:12px}.logs-header h2{font-size:1.3rem;margin:0}.ws-status-indicator{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.2);transition:all .3s ease}.ws-status-indicator i{font-size:.9rem}.logs-container{min-height:300px}.log-item{padding:15px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;margin-bottom:10px;cursor:pointer;position:relative}.log-item,.log-item:after{transition:var(--transition)}.log-item:after{content:"\f06e";font-family:Font Awesome\ 5 Free;font-weight:900;position:absolute;right:15px;top:50%;transform:translateY(-50%);color:var(--text-muted);opacity:0;font-size:1.2rem}.log-item:hover{background:var(--bg-hover);border-color:var(--accent-primary);transform:translateX(2px)}.log-item:hover:after{opacity:1}.log-item:active{transform:scale(.99)}.log-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.log-type{display:inline-block;padding:4px 8px;border-radius:6px;font-size:.8em;font-weight:500;color:#fff!important;text-shadow:0 1px 2px rgba(0,0,0,.3);margin-right:8px}.log-type-badge{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;margin-right:12px;font-size:1.1rem;color:#fff!important;box-shadow:0 2px 6px rgba(0,0,0,.15);transition:var(--transition);flex-shrink:0}.log-type-badge i{filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}.log-type-badge-inline{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:6px;font-size:.8em;font-weight:600;color:#fff!important;box-shadow:0 2px 4px rgba(0,0,0,.2);text-shadow:0 1px 2px rgba(0,0,0,.3);background:linear-gradient(135deg,#6366f105,#00000073)}.log-type-badge-inline i{font-size:.9rem;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}.log-type.info{background:rgba(59,130,246,.2);color:var(--info)}.log-type.success{background:rgba(16,185,129,.2);color:var(--success)}.log-type.warning{background:rgba(245,158,11,.2);color:var(--warning)}.log-type.error{background:rgba(239,68,68,.2);color:var(--error)}.log-timestamp{color:var(--text-muted);font-size:.85rem}.log-message{color:var(--text-primary);margin-bottom:4px}.log-details{color:var(--text-secondary);font-size:.85rem}.access-denied{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-tertiary);border:2px dashed var(--border-color);border-radius:12px;min-height:300px}.access-denied h3{font-weight:600}.access-denied p{color:var(--text-secondary);max-width:400px;line-height:1.5}.empty-state{padding:80px 20px;background:var(--bg-tertiary);border:2px dashed var(--border-color);border-radius:12px;min-height:400px}.empty-state i{font-size:5rem;color:var(--accent-primary);margin-bottom:30px;opacity:.6}.empty-state h3{color:var(--text-primary);font-size:1.8rem;margin-bottom:15px;font-weight:600}.empty-state p{color:var(--text-secondary);font-size:1.1rem;max-width:500px;line-height:1.6}.pagination{display:flex;justify-content:center;align-items:center;gap:15px;margin-top:20px;padding-top:20px;border-top:1px solid var(--border-color)}.page-info{font-size:.9rem}.log-id-local,.page-info{color:var(--text-secondary)}.log-id-local{display:inline-block;padding:3px 8px;background:var(--bg-secondary);font-family:Courier New,monospace;font-size:.8em;font-weight:600;border-radius:4px;border:1px solid var(--border-color)}.log-data-preview{margin-top:8px;font-size:.9em;color:var(--text-secondary);line-height:1.6}.log-data-preview strong{color:var(--text-primary);font-weight:600}.more-data{color:var(--accent-primary);font-weight:600;font-style:italic}.json-display{background:var(--bg-secondary);padding:12px;border-radius:6px;border:1px solid var(--border-color);overflow-x:auto;font-family:Courier New,monospace;font-size:.85em;max-height:300px}.empty-data{text-align:center;padding:20px;color:var(--text-muted);font-style:italic}.log-detail-type-badge{gap:6px;padding:4px 12px;border-radius:6px;font-size:.9em}.log-detail-type-badge i{font-size:.9em}.actions-panel{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:20px;display:none}.actions-panel.active{display:block}.actions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid var(--border-color)}.actions-header h2{font-size:1.3rem}.actions-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));grid-gap:20px;gap:20px;min-height:300px;align-items:start}.actions-container:has(.access-denied),.actions-container:has(.empty-state){display:flex;align-items:center;justify-content:center}.action-item{padding:20px;background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:10px;display:flex;flex-direction:column;gap:12px;height:100%;align-items:stretch}.action-item.full-width{grid-column:1/-1}.action-item form{display:flex;flex-direction:column;align-items:stretch;width:100%;gap:12px;flex-shrink:0}.access-denied{text-align:center;padding:60px 20px;color:var(--text-secondary)}.access-denied i{font-size:4rem;color:var(--text-muted);margin-bottom:20px;opacity:.5}.access-denied h3{font-size:1.5rem;color:var(--text-primary);margin-bottom:10px}.access-denied p{font-size:1rem;line-height:1.6}.action-button{padding:20px;background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:10px;cursor:pointer;transition:var(--transition);text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;min-height:150px;height:100%}.action-button:hover{background:var(--bg-hover);border-color:var(--accent-primary);transform:translateY(-4px);box-shadow:var(--shadow-lg)}.action-button:active{transform:translateY(-2px)}.action-button .action-icon{font-size:2.5rem;color:var(--accent-primary);display:flex;align-items:center;justify-content:center}.action-button .action-icon i{font-size:inherit}.action-button .action-label{font-weight:500;font-size:1rem;color:var(--text-primary);word-break:break-word;text-align:center}.action-button .action-description{font-size:.85rem;color:var(--text-secondary);word-break:break-word;text-align:center;line-height:1.4}.action-button.loading{opacity:.6;pointer-events:none;position:relative}.action-button.loading .action-description,.action-button.loading .action-icon,.action-button.loading .action-label{visibility:hidden}.action-button.loading:after{top:50%;left:50%;transform:translate(-50%,-50%);border:2px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;width:20px;height:20px;animation:spin .8s linear infinite}.btn-re-execute{margin-top:12px;background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);transition:var(--transition)}.btn-re-execute:hover{border-color:var(--accent-primary)}.action-button.success{border-color:var(--success)!important;animation:pulse-success .6s ease}.action-button.error{border-color:var(--error)!important;animation:pulse-error .6s ease}@keyframes pulse-success{0%,to{border-color:var(--success)}50%{border-color:var(--success);box-shadow:0 0 20px rgba(16,185,129,.3)}}@keyframes pulse-error{0%,to{border-color:var(--error)}50%{border-color:var(--error);box-shadow:0 0 20px rgba(239,68,68,.3)}}.action-field{display:flex;flex-direction:column;gap:8px;width:100%}.action-field label{font-size:.9rem;font-weight:500;color:var(--text-primary);display:flex;align-items:center;gap:6px}.action-field label .required{color:var(--error)}.action-field input[type=email],.action-field input[type=number],.action-field input[type=password],.action-field input[type=text],.action-field select,.action-field textarea{width:100%;padding:10px 12px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:.95rem;transition:var(--transition);font-family:inherit;box-sizing:border-box}.action-field input:focus,.action-field select:focus,.action-field textarea:focus{outline:none;border-color:var(--accent-primary);background:var(--bg-hover)}.action-field input[type=number]{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.action-field input[type=number]::-webkit-inner-spin-button,.action-field input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.action-field-number-wrapper{position:relative;display:flex;align-items:stretch;width:100%}.action-field-number-wrapper input[type=number]{flex:1 1;padding-right:45px;width:100%;box-sizing:border-box}.number-controls{position:absolute;right:1px;top:1px;bottom:1px;flex-direction:column;width:38px;border-radius:0 7px 7px 0;overflow:hidden}.number-btn,.number-controls{display:flex;background:var(--bg-tertiary)}.number-btn{flex:1 1;align-items:center;justify-content:center;border:none;border-left:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;transition:var(--transition);font-size:14px;-webkit-user-select:none;-moz-user-select:none;user-select:none}.number-btn:hover{background:var(--bg-hover);color:var(--accent-primary)}.number-btn:active{background:var(--accent-primary);color:#fff}.number-btn:first-child{border-bottom:.5px solid var(--border-color)}.number-btn i{pointer-events:none}.action-field textarea{resize:vertical;min-height:80px}.action-field select{cursor:pointer;padding-right:35px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23888' d='M1.41 0L6 4.59L10.59 0L12 1.41l-6 6l-6-6z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:12px;-webkit-appearance:none;-moz-appearance:none;appearance:none}.action-field select:hover{background-color:var(--bg-hover);border-color:var(--accent-secondary)}.action-field select option{background:var(--bg-primary);color:var(--text-primary);padding:10px}.action-field-checkbox,.action-field-radio{display:flex;align-items:center;gap:10px;padding:10px;width:100%;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;cursor:pointer;transition:var(--transition);box-sizing:border-box}.action-field-checkbox:hover,.action-field-radio:hover{background:var(--bg-hover)}.action-field-checkbox input[type=checkbox],.action-field-radio input[type=radio]{width:18px;height:18px;cursor:pointer;accent-color:var(--accent-primary)}.action-field-checkbox label,.action-field-radio label{cursor:pointer;margin:0;flex:1 1}.action-field-group{display:flex;flex-direction:column;gap:8px;padding:15px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px}.action-field-group-title{font-size:.9rem;font-weight:600;color:var(--text-primary);margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid var(--border-color)}.action-form-header{display:flex;align-items:center;gap:10px;margin-bottom:15px}.action-form-icon{font-size:1.5rem}.action-form-title{font-weight:500;color:var(--text-primary);font-size:1rem}.action-form-description{font-size:.875rem;color:var(--text-secondary);margin-top:2px}.action-submit-btn{margin-top:10px;margin-left:auto;margin-right:auto;padding:0!important;background:var(--accent-primary);color:#fff;border:none!important;border-radius:8px;font-weight:500;cursor:pointer;transition:background-color .2s ease;display:flex!important;align-items:center;justify-content:center;width:140px!important;height:44px!important;min-width:140px!important;max-width:140px!important;min-height:44px!important;max-height:44px!important;position:relative;flex-shrink:0;white-space:nowrap;overflow:hidden;box-sizing:border-box!important}.action-submit-btn span{display:block;width:100%;text-align:center;line-height:44px;font-size:14px}.action-submit-btn:active,.action-submit-btn:hover{background:var(--accent-hover)}.action-submit-btn:disabled{opacity:.5;cursor:not-allowed}.action-submit-btn.loading{pointer-events:none}.action-submit-btn.loading span{opacity:0;visibility:hidden}.action-submit-btn.loading:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;margin:auto;border:2px solid hsla(0,0%,100%,.3);border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:spin .8s linear infinite}.action-submit-btn.success{background:var(--success)!important;animation:pulse-btn-success .6s ease}.action-submit-btn.error{background:var(--error)!important;animation:pulse-btn-error .6s ease}@keyframes pulse-btn-success{0%,to{background:var(--success)}50%{background:var(--success);transform:scale(1.05)}}@keyframes pulse-btn-error{0%,to{background:var(--error)}50%{background:var(--error);transform:scale(1.05)}}.options-container{margin-top:10px;display:flex;flex-direction:column;gap:8px}.option-item{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;padding:8px}.option-inputs{display:flex;align-items:center;gap:8px}.option-input-group{flex:1 1;display:flex;flex-direction:column;gap:4px}.option-label-small{font-size:.75rem;color:var(--text-secondary);font-weight:500}.option-input-group input{padding:6px 10px;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-tertiary);color:var(--text-primary);font-size:.9rem}.option-input-group input:focus{outline:none;border-color:var(--accent-primary)}.remove-option-btn{padding:6px 10px;background:var(--danger-color);color:#fff;border:none;border-radius:4px;cursor:pointer;transition:var(--transition);font-size:.85rem;align-self:flex-end;margin-bottom:2px}.remove-option-btn:hover{background:#c0392b}.btn-add-option{margin-top:8px;padding:8px 14px;background:var(--accent-secondary);color:#fff;border:none;border-radius:6px;cursor:pointer;transition:var(--transition);font-size:.9rem;font-weight:500;display:inline-flex;align-items:center;gap:6px}.btn-add-option:hover{background:var(--accent-hover);transform:translateY(-1px)}.btn-add-option i{font-size:.85rem}.action-result{display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 16px;background:rgba(var(--success-rgb,46,213,115),.1);border:1px solid rgba(var(--success-rgb,46,213,115),.3);border-radius:8px;margin-top:12px;cursor:pointer;transition:all .3s ease;opacity:0;transform:translateY(10px)}.action-result:hover{background:rgba(var(--success-rgb,46,213,115),.15);border-color:rgba(var(--success-rgb,46,213,115),.5)}.action-result .result-label{font-size:.9rem;font-weight:500;color:var(--text-secondary)}.action-result .result-value{flex:0 1 auto;font-size:1rem;font-weight:600;color:var(--text-primary);font-family:Courier New,monospace;word-break:break-all;text-align:center}.action-result .result-copy-icon{font-size:1rem;color:var(--text-secondary);transition:all .2s ease}.action-result:hover .result-copy-icon{color:var(--primary)}.action-result .result-copy-icon.copied{color:var(--success)}.copy-message{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:var(--success);color:#fff;padding:4px 12px;border-radius:4px;font-size:.85rem;font-weight:500;animation:copyMessageFade 2s ease;pointer-events:none}@keyframes copyMessageFade{0%{opacity:0;transform:translateY(-50%) translateX(10px)}10%{opacity:1;transform:translateY(-50%) translateX(0)}90%{opacity:1;transform:translateY(-50%) translateX(0)}to{opacity:0;transform:translateY(-50%) translateX(10px)}}.btn-re-execute{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:transparent;border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);font-size:.9rem;cursor:pointer;transition:all .2s ease;margin-top:8px}.btn-re-execute:hover{background:var(--bg-hover);border-color:var(--primary);color:var(--primary)}.btn-re-execute i{font-size:.85rem}.action-button,.action-item .action-result{position:relative}.action-button{overflow:hidden}.action-button.loading:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.1),transparent);animation:loadingShimmer 1.5s infinite}@keyframes loadingShimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);display:flex;justify-content:center;align-items:center;z-index:1100;animation:fadeIn .3s ease-out;overflow-y:auto;overscroll-behavior:contain}body.modal-open{overflow:hidden;overscroll-behavior:none}.modal-content{background:#252538;border:1px solid var(--border-color);border-radius:16px;width:90%;max-width:500px;max-height:80vh;overflow-y:auto;animation:slideUp .3s ease-out;overscroll-behavior:contain}.modal-content-large{max-width:700px}.modal-content-medium{max-width:600px}.modal-content-filters{max-width:900px;width:95%;max-height:85vh;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--border-color);flex-shrink:0}.modal-header h3{font-size:1.3rem}.modal-close{background:none;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;transition:var(--transition);width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px}.modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-body{padding:20px;flex:1 1;overflow-y:auto;min-height:0}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:20px;border-top:1px solid var(--border-color);flex-shrink:0;background:var(--bg-tertiary)}.filter-options{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:12px;gap:12px;padding:2px;min-height:200px}.filter-options:has(.empty-state){display:flex;align-items:center;justify-content:center}@media (max-width:968px){.filter-options{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}}@media (max-width:640px){.filter-options{grid-template-columns:1fr}.modal-content-filters{max-width:95%}}.filter-option{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;cursor:pointer;transition:var(--transition)}.filter-option:hover{background:var(--bg-hover)}.filter-option input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:var(--accent-primary)}.filter-option label{flex:1 1;cursor:pointer;color:var(--text-primary);display:flex;align-items:center;gap:8px}.log-type-indicator{width:12px;height:12px;border-radius:50%;display:inline-block;border:1px solid var(--border-color)}.log-type-badge-filter{display:inline-flex;align-items:center;gap:8px;margin-right:8px;position:relative}.badge-color-box{width:32px;height:32px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 2px 4px rgba(0,0,0,.15);flex-shrink:0;background:linear-gradient(135deg,#6366f105,#00000073)}.log-type-badge-filter i{font-size:1rem;position:absolute;left:8px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}.filter-option .checkbox-label{display:flex;align-items:center;gap:0}.log-detail-grid{display:grid;grid-template-columns:1fr;grid-gap:15px;gap:15px}.log-detail-section{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;padding:15px}.log-detail-section-title{font-size:1rem;font-weight:600;color:var(--accent-primary);margin-bottom:12px;display:flex;align-items:center;gap:8px}.log-detail-section-title i{font-size:.9rem}.log-detail-row{display:flex;justify-content:space-between;align-items:flex-start;padding:8px 0;border-bottom:1px solid var(--border-color)}.log-detail-row:last-child{border-bottom:none}.log-detail-label{font-weight:500;color:var(--text-secondary);min-width:120px}.log-detail-value{color:var(--text-primary);text-align:right;word-break:break-word;flex:1 1}.log-detail-value.monospace{font-family:Courier New,monospace;font-size:.9rem;background:var(--bg-primary);padding:4px 8px;border-radius:4px}.log-detail-copyable{display:flex;align-items:center;gap:8px}.log-detail-copyable .monospace{font-family:Courier New,monospace;font-size:.9rem;background:var(--bg-primary);padding:4px 8px;border-radius:4px;flex:1 1}.copy-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-secondary);padding:6px 8px;border-radius:6px;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center;min-width:32px;height:32px}.copy-btn:hover{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.copy-btn:active{transform:scale(.95)}.copy-btn i{font-size:.9rem}.log-detail-type-badge{display:inline-flex;align-items:center;gap:7px;padding:5px 12px;border-radius:8px;font-size:.85rem;font-weight:600;color:#fff;box-shadow:0 2px 6px rgba(0,0,0,.2);text-shadow:0 1px 2px rgba(0,0,0,.3);background:linear-gradient(135deg,#6366f105,#00000073)}.log-detail-type-badge i{font-size:1rem;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}.log-detail-timestamp{display:flex;align-items:center;justify-content:flex-end;gap:8px;font-size:.95rem}.log-detail-timestamp i{color:var(--accent-primary)}.settings-tabs{display:flex;gap:10px;margin-bottom:25px;border-bottom:2px solid var(--border-color)}.settings-tab{flex:1 1;padding:12px;background:none;border:none;color:var(--text-secondary);font-size:.95rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;font-weight:500;display:flex;align-items:center;justify-content:center;gap:8px}.settings-tab i{font-size:1rem}.settings-tab:hover{color:var(--text-primary)}.settings-tab.active{color:var(--accent-primary)}.settings-tab.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--accent-primary);animation:expandWidth .4s cubic-bezier(.4,0,.2,1)}.settings-content{position:relative;min-height:500px;max-height:500px;overflow-y:auto}@media (max-width:768px){.settings-content{max-height:none}}.settings-panel{display:none;animation:fadeIn .3s ease-out;position:absolute;top:0;left:0;right:0;opacity:0}.settings-panel.active{display:block;position:relative;opacity:1}.settings-panel h4{font-size:1.1rem;margin-bottom:20px;color:var(--text-primary)}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:var(--text-secondary);font-size:.9rem;display:flex;align-items:center;gap:6px}.form-group label i{color:var(--accent-primary)}.form-input{width:100%;padding:12px 16px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:1rem;transition:var(--transition)}.form-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px rgba(99,102,241,.1)}.form-input:disabled,.form-input[readonly]{opacity:.6;cursor:not-allowed}.form-hint{display:block;margin-top:6px;font-size:.85rem;color:var(--text-muted)}.info-text{padding:10px 14px;background:var(--bg-tertiary);border-radius:6px}.info-banner,.info-text{color:var(--text-primary);font-size:.95rem}.info-banner{padding:15px;background:rgba(59,130,246,.1);border-left:3px solid var(--info);border-radius:8px;display:flex;align-items:center;gap:10px;margin-bottom:20px}.info-banner i{color:var(--info);font-size:1.2rem}.projects-preview{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.project-item-preview{display:flex;align-items:center;gap:15px;padding:15px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;opacity:.7}.project-icon{width:45px;height:45px;background:var(--bg-hover);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--accent-primary);font-size:1.3rem}.project-info{flex:1 1}.project-info h5{font-size:1rem;margin-bottom:4px;color:var(--text-primary)}.project-info small{color:var(--text-muted);font-size:.85rem}.project-actions{display:flex;gap:8px}.btn-icon-small{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:6px;border-radius:6px;transition:var(--transition);font-size:1rem}.btn-icon-small:hover:not(:disabled){background:var(--bg-hover);color:var(--accent-primary)}.btn-icon-small:disabled{opacity:.4;cursor:not-allowed}.projects-settings-list{display:flex;flex-direction:column;gap:1rem}.project-settings-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;transition:var(--transition)}.project-settings-card:hover{border-color:var(--accent-primary);box-shadow:0 0 0 1px var(--accent-primary)}.project-settings-icon{width:50px;height:50px;background:var(--accent-primary);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;flex-shrink:0}.project-settings-info{flex:1 1;min-width:0}.project-settings-name{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0 0 .375rem}.project-settings-description{font-size:.875rem;color:var(--text-secondary);margin:0 0 .25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-settings-id{font-size:.8125rem;color:var(--text-muted);font-family:Courier New,monospace}.project-settings-actions{flex-shrink:0}.btn-manage-project{white-space:nowrap}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;color:var(--text-secondary)}.loading i{font-size:2rem;margin-bottom:1rem}.empty-state{padding:3rem 1rem;color:var(--text-secondary)}.empty-state i{font-size:3rem}.empty-state p{font-size:1rem}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;color:var(--error-color)}.error-state i{font-size:3rem;margin-bottom:1rem}.error-state p{margin:0;font-size:1rem}.loader-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:10000;opacity:0;animation:fadeIn .3s ease forwards}.loader-content{text-align:center;color:#fff}.spinner{border:4px solid hsla(0,0%,100%,.3);border-top-color:#fff;border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite;margin:0 auto 1rem}.toast{position:fixed;bottom:2rem;right:2rem;padding:1rem 1.5rem;border-radius:8px;color:#fff;font-weight:500;box-shadow:0 4px 12px rgba(0,0,0,.15);z-index:9999;display:flex;align-items:center;gap:.75rem;transform:translateX(400px);opacity:0;transition:all .3s ease;max-width:400px}.toast.show{transform:translateX(0);opacity:1}.toast i{font-size:1.25rem}.toast-success{background:linear-gradient(135deg,#2ecc71,#27ae60)}.toast-error{background:linear-gradient(135deg,#e74c3c,#c0392b)}.toast-info{background:linear-gradient(135deg,#3498db,#2980b9)}.toast-warning{background:linear-gradient(135deg,#f39c12,#e67e22)}.confirm-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:10001;opacity:0;transition:opacity .3s ease}.confirm-modal-overlay.show{opacity:1}.confirm-modal{background:#fff;border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.2);max-width:500px;width:90%;transform:scale(.9);transition:transform .3s ease}.confirm-modal-overlay.show .confirm-modal{transform:scale(1)}.confirm-modal-header{padding:1.5rem;border-bottom:1px solid #ecf0f1;display:flex;align-items:center;gap:1rem}.confirm-modal-header i{font-size:2rem;color:#f39c12}.confirm-modal-header h3{margin:0;font-size:1.25rem;color:#2c3e50}.confirm-modal-body{padding:1.5rem}.confirm-modal-body p{margin:0;color:#7f8c8d;line-height:1.6}.confirm-modal-footer{padding:1rem 1.5rem;border-top:1px solid #ecf0f1;display:flex;justify-content:flex-end;gap:.75rem}.critical-error{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.9);display:flex;align-items:center;justify-content:center;z-index:10002}.critical-error-content{background:#fff;padding:3rem;border-radius:12px;text-align:center;max-width:500px;box-shadow:0 8px 32px rgba(0,0,0,.3)}.critical-error-content i{font-size:4rem;color:#e74c3c;margin-bottom:1rem}.critical-error-content h2{margin:0 0 1rem;color:#2c3e50}.critical-error-content p{margin:0 0 2rem;color:#7f8c8d;line-height:1.6}.btn.loading{position:relative;pointer-events:none;opacity:.7}.btn.loading:after{content:"";position:absolute;width:16px;height:16px;top:50%;left:50%;margin-left:-8px;margin-top:-8px;border:2px solid hsla(0,0%,100%,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.skeleton{background:linear-gradient(90deg,#f0f0f0,#e0e0e0 50%,#f0f0f0);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite;border-radius:4px}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:1rem;margin-bottom:.5rem}.skeleton-title{height:1.5rem;width:60%;margin-bottom:1rem}.skeleton-card{height:200px;margin-bottom:1rem}.empty-state{text-align:center;padding:3rem;color:#95a5a6;height:100%;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center}.empty-state i{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-state h3{margin:0 0 .5rem;color:#7f8c8d}.empty-state p{margin:0;font-size:.9rem}.welcome-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,var(--bg-primary) 0,var(--bg-secondary) 100%);display:flex;display:-moz-flex;flex-direction:column;-moz-flex-direction:column;justify-content:center;-webkit-justify-content:center;-moz-justify-content:center;align-items:center;-webkit-align-items:center;-moz-align-items:center;z-index:10000;opacity:1;transition:opacity .6s ease-out}.welcome-overlay.hidden{opacity:0;pointer-events:none}.welcome-content{text-align:center;color:var(--text-primary)}.welcome-icon{width:120px;height:120px;margin:0 auto 30px;background:linear-gradient(135deg,var(--accent-primary),var(--accent-light));border-radius:30px;display:flex;display:-moz-flex;flex-direction:column;-moz-flex-direction:column;justify-content:center;-webkit-justify-content:center;-moz-justify-content:center;align-items:center;-webkit-align-items:center;-moz-align-items:center;font-size:3.5rem;color:#fff;box-shadow:0 10px 40px rgba(0,0,0,.3);will-change:transform,opacity;transform:translateZ(0);opacity:0;transform:scale(0) rotate(-180deg)}.welcome-overlay.active .welcome-icon{animation:welcomeIconAnimation 1.5s ease-out forwards!important}@keyframes welcomeIconAnimation{0%{transform:scale(0) rotate(-180deg);opacity:0}60%{transform:scale(1.1) rotate(10deg)}80%{transform:scale(.95) rotate(-5deg)}to{transform:scale(1) rotate(0deg);opacity:1}}.welcome-message{font-size:2.5rem;font-weight:700;margin-bottom:15px;color:var(--text-primary);opacity:0}.welcome-overlay.active .welcome-message{animation:fadeInUp .8s ease-out .3s forwards!important}.welcome-username{font-size:3rem;font-weight:800;background:linear-gradient(135deg,var(--accent-primary),var(--accent-light));-webkit-background-clip:text;-moz-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;-moz-text-fill-color:transparent;color:transparent;margin:20px auto;opacity:0;overflow:hidden;white-space:nowrap;border-right:3px solid var(--accent-primary);max-width:fit-content;max-width:-moz-fit-content;max-width:-webkit-fit-content;width:0}.welcome-overlay.active .welcome-username{animation:typeWriter 1.5s steps(30) .8s forwards,fadeIn .5s ease-out .8s forwards!important}@keyframes typeWriter{0%{width:0}to{width:100%}}@keyframes fadeIn{to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.welcome-subtitle{font-size:1.3rem;color:var(--text-secondary);font-weight:400;opacity:0}.welcome-overlay.active .welcome-subtitle{animation:fadeInUp .8s ease-out 2.5s forwards!important}.welcome-loader{margin-top:40px;opacity:0}.welcome-overlay.active .welcome-loader{animation:fadeIn .5s ease-out 3s forwards!important}.welcome-spinner{width:60px;height:60px;margin:0 auto;border-radius:50%;position:relative;will-change:transform;animation:spin 1.2s linear infinite!important;transform:translateZ(0);-webkit-backface-visibility:hidden;backface-visibility:hidden}.welcome-spinner:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;border-radius:50%;border-color:#4a90e2 #357abd transparent transparent;border-style:solid;border-width:4px}.welcome-spinner:after{content:"";position:absolute;top:8px;left:8px;right:8px;bottom:8px;border-radius:50%;border-color:#7cb3f5 transparent transparent #5a9de5;border-style:solid;border-width:3px;animation:spin .8s linear infinite reverse!important}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.welcome-dots{margin-top:15px;font-size:1.2rem;color:var(--text-secondary);letter-spacing:3px}.welcome-overlay.welcome-back .welcome-message{font-size:2rem}.welcome-overlay.welcome-back.active .welcome-icon{animation:welcomeBackIcon 1s ease-out forwards!important}@keyframes welcomeBackIcon{0%{transform:translateY(-100px);opacity:0}60%{transform:translateY(10px)}80%{transform:translateY(-5px)}to{transform:translateY(0);opacity:1}}.welcome-overlay.fade-out{animation:fadeOutScale .8s ease-out forwards}@keyframes fadeOutScale{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.1)}}@media (max-width:768px){.welcome-icon{width:90px;height:90px;font-size:2.5rem}.welcome-message{font-size:1.8rem}.welcome-username{font-size:2rem;margin-left:auto;margin-right:auto;text-align:center}.welcome-subtitle{font-size:1rem;padding:0 20px}}@media (max-width:480px){.welcome-icon{width:70px;height:70px;font-size:2rem}.welcome-message{font-size:1.5rem}.welcome-username{font-size:1.5rem;margin-left:auto;margin-right:auto;text-align:center}.welcome-subtitle{font-size:.9rem}.welcome-content{width:100%;display:flex;display:-webkit-flex;flex-direction:column;align-items:center;-webkit-align-items:center}}