body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.slide-in{animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translateX(-100%)}to{transform:translateX(0)}}:root{--toastify-color-light:#fff;--toastify-color-dark:#121212;--toastify-color-info:#3498db;--toastify-color-success:#07bc0c;--toastify-color-warning:#f1c40f;--toastify-color-error:#e74c3c;--toastify-color-transparent:#ffffffb3;--toastify-icon-color-info:var(--toastify-color-info);--toastify-icon-color-success:var(--toastify-color-success);--toastify-icon-color-warning:var(--toastify-color-warning);--toastify-icon-color-error:var(--toastify-color-error);--toastify-toast-width:320px;--toastify-toast-background:#fff;--toastify-toast-min-height:64px;--toastify-toast-max-height:800px;--toastify-font-family:sans-serif;--toastify-z-index:9999;--toastify-text-color-light:#757575;--toastify-text-color-dark:#fff;--toastify-text-color-info:#fff;--toastify-text-color-success:#fff;--toastify-text-color-warning:#fff;--toastify-text-color-error:#fff;--toastify-spinner-color:#616161;--toastify-spinner-color-empty-area:#e0e0e0;--toastify-color-progress-light:linear-gradient(90deg,#4cd964,#5ac8fa,#007aff,#34aadc,#5856d6,#ff2d55);--toastify-color-progress-dark:#bb86fc;--toastify-color-progress-info:var(--toastify-color-info);--toastify-color-progress-success:var(--toastify-color-success);--toastify-color-progress-warning:var(--toastify-color-warning);--toastify-color-progress-error:var(--toastify-color-error)}.Toastify__toast-container{box-sizing:border-box;color:#fff;padding:4px;position:fixed;-webkit-transform:translateZ(9999);-webkit-transform:translateZ(var(--toastify-z-index));width:320px;width:var(--toastify-toast-width);z-index:9999;z-index:var(--toastify-z-index)}.Toastify__toast-container--top-left{left:1em;top:1em}.Toastify__toast-container--top-center{left:50%;top:1em;transform:translateX(-50%)}.Toastify__toast-container--top-right{right:1em;top:1em}.Toastify__toast-container--bottom-left{bottom:1em;left:1em}.Toastify__toast-container--bottom-center{bottom:1em;left:50%;transform:translateX(-50%)}.Toastify__toast-container--bottom-right{bottom:1em;right:1em}@media only screen and (max-width:480px){.Toastify__toast-container{left:0;margin:0;padding:0;width:100vw}.Toastify__toast-container--top-center,.Toastify__toast-container--top-left,.Toastify__toast-container--top-right{top:0;transform:translateX(0)}.Toastify__toast-container--bottom-center,.Toastify__toast-container--bottom-left,.Toastify__toast-container--bottom-right{bottom:0;transform:translateX(0)}.Toastify__toast-container--rtl{left:auto;right:0}}.Toastify__toast{border-radius:4px;box-shadow:0 1px 10px 0 #0000001a,0 2px 15px 0 #0000000d;box-sizing:border-box;cursor:default;direction:ltr;display:flex;font-family:sans-serif;font-family:var(--toastify-font-family);justify-content:space-between;margin-bottom:1rem;max-height:800px;max-height:var(--toastify-toast-max-height);min-height:64px;min-height:var(--toastify-toast-min-height);overflow:hidden;padding:8px;position:relative;z-index:0}.Toastify__toast--rtl{direction:rtl}.Toastify__toast--close-on-click{cursor:pointer}.Toastify__toast-body{align-items:center;display:flex;flex:1 1 auto;margin:auto 0;padding:6px}.Toastify__toast-body>div:last-child{flex:1 1;word-break:break-word}.Toastify__toast-icon{-webkit-margin-end:10px;display:flex;flex-shrink:0;margin-inline-end:10px;width:20px}.Toastify--animate{animation-duration:.7s;animation-fill-mode:both}.Toastify--animate-icon{animation-duration:.3s;animation-fill-mode:both}@media only screen and (max-width:480px){.Toastify__toast{border-radius:0;margin-bottom:0}}.Toastify__toast-theme--dark{background:#121212;background:var(--toastify-color-dark);color:#fff;color:var(--toastify-text-color-dark)}.Toastify__toast-theme--colored.Toastify__toast--default,.Toastify__toast-theme--light{background:#fff;background:var(--toastify-color-light);color:#757575;color:var(--toastify-text-color-light)}.Toastify__toast-theme--colored.Toastify__toast--info{background:#3498db;background:var(--toastify-color-info);color:#fff;color:var(--toastify-text-color-info)}.Toastify__toast-theme--colored.Toastify__toast--success{background:#07bc0c;background:var(--toastify-color-success);color:#fff;color:var(--toastify-text-color-success)}.Toastify__toast-theme--colored.Toastify__toast--warning{background:#f1c40f;background:var(--toastify-color-warning);color:#fff;color:var(--toastify-text-color-warning)}.Toastify__toast-theme--colored.Toastify__toast--error{background:#e74c3c;background:var(--toastify-color-error);color:#fff;color:var(--toastify-text-color-error)}.Toastify__progress-bar-theme--light{background:linear-gradient(90deg,#4cd964,#5ac8fa,#007aff,#34aadc,#5856d6,#ff2d55);background:var(--toastify-color-progress-light)}.Toastify__progress-bar-theme--dark{background:#bb86fc;background:var(--toastify-color-progress-dark)}.Toastify__progress-bar--info{background:#3498db;background:var(--toastify-color-progress-info)}.Toastify__progress-bar--success{background:#07bc0c;background:var(--toastify-color-progress-success)}.Toastify__progress-bar--warning{background:#f1c40f;background:var(--toastify-color-progress-warning)}.Toastify__progress-bar--error{background:#e74c3c;background:var(--toastify-color-progress-error)}.Toastify__progress-bar-theme--colored.Toastify__progress-bar--error,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--info,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--success,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--warning{background:#ffffffb3;background:var(--toastify-color-transparent)}.Toastify__close-button{align-self:flex-start;background:#0000;border:none;color:#fff;cursor:pointer;opacity:.7;outline:none;padding:0;transition:.3s ease}.Toastify__close-button--light{color:#000;opacity:.3}.Toastify__close-button>svg{fill:currentColor;height:16px;width:14px}.Toastify__close-button:focus,.Toastify__close-button:hover{opacity:1}@keyframes Toastify__trackProgress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.Toastify__progress-bar{bottom:0;height:5px;left:0;opacity:.7;position:absolute;transform-origin:left;width:100%;z-index:9999;z-index:var(--toastify-z-index)}.Toastify__progress-bar--animated{animation:Toastify__trackProgress linear 1 forwards}.Toastify__progress-bar--controlled{transition:transform .2s}.Toastify__progress-bar--rtl{left:auto;right:0;transform-origin:right}.Toastify__spinner{animation:Toastify__spin .65s linear infinite;border:2px solid #e0e0e0;border-color:var(--toastify-spinner-color-empty-area);border-radius:100%;border-right-color:#616161;border-right-color:var(--toastify-spinner-color);box-sizing:border-box;height:20px;width:20px}@keyframes Toastify__bounceInRight{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(3000px,0,0)}60%{opacity:1;transform:translate3d(-25px,0,0)}75%{transform:translate3d(10px,0,0)}90%{transform:translate3d(-5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutRight{20%{opacity:1;transform:translate3d(-20px,0,0)}to{opacity:0;transform:translate3d(2000px,0,0)}}@keyframes Toastify__bounceInLeft{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(-3000px,0,0)}60%{opacity:1;transform:translate3d(25px,0,0)}75%{transform:translate3d(-10px,0,0)}90%{transform:translate3d(5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutLeft{20%{opacity:1;transform:translate3d(20px,0,0)}to{opacity:0;transform:translate3d(-2000px,0,0)}}@keyframes Toastify__bounceInUp{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,3000px,0)}60%{opacity:1;transform:translate3d(0,-20px,0)}75%{transform:translate3d(0,10px,0)}90%{transform:translate3d(0,-5px,0)}to{transform:translateZ(0)}}@keyframes Toastify__bounceOutUp{20%{transform:translate3d(0,-10px,0)}40%,45%{opacity:1;transform:translate3d(0,20px,0)}to{opacity:0;transform:translate3d(0,-2000px,0)}}@keyframes Toastify__bounceInDown{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,-3000px,0)}60%{opacity:1;transform:translate3d(0,25px,0)}75%{transform:translate3d(0,-10px,0)}90%{transform:translate3d(0,5px,0)}to{transform:none}}@keyframes Toastify__bounceOutDown{20%{transform:translate3d(0,10px,0)}40%,45%{opacity:1;transform:translate3d(0,-20px,0)}to{opacity:0;transform:translate3d(0,2000px,0)}}.Toastify__bounce-enter--bottom-left,.Toastify__bounce-enter--top-left{animation-name:Toastify__bounceInLeft}.Toastify__bounce-enter--bottom-right,.Toastify__bounce-enter--top-right{animation-name:Toastify__bounceInRight}.Toastify__bounce-enter--top-center{animation-name:Toastify__bounceInDown}.Toastify__bounce-enter--bottom-center{animation-name:Toastify__bounceInUp}.Toastify__bounce-exit--bottom-left,.Toastify__bounce-exit--top-left{animation-name:Toastify__bounceOutLeft}.Toastify__bounce-exit--bottom-right,.Toastify__bounce-exit--top-right{animation-name:Toastify__bounceOutRight}.Toastify__bounce-exit--top-center{animation-name:Toastify__bounceOutUp}.Toastify__bounce-exit--bottom-center{animation-name:Toastify__bounceOutDown}@keyframes Toastify__zoomIn{0%{opacity:0;transform:scale3d(.3,.3,.3)}50%{opacity:1}}@keyframes Toastify__zoomOut{0%{opacity:1}50%{opacity:0;transform:scale3d(.3,.3,.3)}to{opacity:0}}.Toastify__zoom-enter{animation-name:Toastify__zoomIn}.Toastify__zoom-exit{animation-name:Toastify__zoomOut}@keyframes Toastify__flipIn{0%{animation-timing-function:ease-in;opacity:0;transform:perspective(400px) rotateX(90deg)}40%{animation-timing-function:ease-in;transform:perspective(400px) rotateX(-20deg)}60%{opacity:1;transform:perspective(400px) rotateX(10deg)}80%{transform:perspective(400px) rotateX(-5deg)}to{transform:perspective(400px)}}@keyframes Toastify__flipOut{0%{transform:perspective(400px)}30%{opacity:1;transform:perspective(400px) rotateX(-20deg)}to{opacity:0;transform:perspective(400px) rotateX(90deg)}}.Toastify__flip-enter{animation-name:Toastify__flipIn}.Toastify__flip-exit{animation-name:Toastify__flipOut}@keyframes Toastify__slideInRight{0%{transform:translate3d(110%,0,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideInLeft{0%{transform:translate3d(-110%,0,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideInUp{0%{transform:translate3d(0,110%,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideInDown{0%{transform:translate3d(0,-110%,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideOutRight{0%{transform:translateZ(0)}to{transform:translate3d(110%,0,0);visibility:hidden}}@keyframes Toastify__slideOutLeft{0%{transform:translateZ(0)}to{transform:translate3d(-110%,0,0);visibility:hidden}}@keyframes Toastify__slideOutDown{0%{transform:translateZ(0)}to{transform:translate3d(0,500px,0);visibility:hidden}}@keyframes Toastify__slideOutUp{0%{transform:translateZ(0)}to{transform:translate3d(0,-500px,0);visibility:hidden}}.Toastify__slide-enter--bottom-left,.Toastify__slide-enter--top-left{animation-name:Toastify__slideInLeft}.Toastify__slide-enter--bottom-right,.Toastify__slide-enter--top-right{animation-name:Toastify__slideInRight}.Toastify__slide-enter--top-center{animation-name:Toastify__slideInDown}.Toastify__slide-enter--bottom-center{animation-name:Toastify__slideInUp}.Toastify__slide-exit--bottom-left,.Toastify__slide-exit--top-left{animation-name:Toastify__slideOutLeft}.Toastify__slide-exit--bottom-right,.Toastify__slide-exit--top-right{animation-name:Toastify__slideOutRight}.Toastify__slide-exit--top-center{animation-name:Toastify__slideOutUp}.Toastify__slide-exit--bottom-center{animation-name:Toastify__slideOutDown}@keyframes Toastify__spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:20px;position:relative}.login-background{height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%;z-index:1}.bg-shape{animation:float 6s ease-in-out infinite;background:#ffffff1a;border-radius:50%;position:absolute}.shape-1{animation-delay:0s;height:200px;left:10%;top:10%;width:200px}.shape-2{animation-delay:2s;height:150px;right:15%;top:60%;width:150px}.shape-3{animation-delay:4s;bottom:20%;height:100px;left:20%;width:100px}@keyframes float{0%,to{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-20px) rotate(180deg)}}.login-card{animation:slideUp .6s ease-out;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff2;border:1px solid #fff3;border-radius:20px;box-shadow:0 20px 40px #0000001a;max-width:450px;padding:40px;position:relative;width:100%;z-index:2}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-card:before{background:linear-gradient(90deg,#667eea,#764ba2);border-radius:20px 20px 0 0;content:"";height:4px;left:0;position:absolute;right:0;top:0}.login-header{margin-bottom:30px;text-align:center}.logo h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:700;margin-bottom:10px}.logo h1 span{color:#ff6b6b}.login-header h2{color:#2c3e50;font-size:1.8rem;font-weight:600;margin-bottom:8px}.login-header p{color:#7f8c8d;font-size:1rem;margin:0}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{gap:8px}.form-group label{color:#2c3e50;font-size:.95rem}.input-wrapper{align-items:center;display:flex;position:relative}.input-wrapper i{color:#7f8c8d;font-size:1.1rem;left:15px;position:absolute;z-index:1}.input-wrapper input{background:#f8f9fa;border:2px solid #e9ecef;border-radius:12px;box-sizing:border-box;font-size:1rem;padding:15px 15px 15px 45px;transition:all .3s ease;width:100%}.input-wrapper input:focus{background:#fff;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none;transform:translateY(-2px)}.input-wrapper input:disabled{background:#f1f3f4;cursor:not-allowed;opacity:.7}.error-message{align-items:center;animation:shake .5s ease-in-out;background:linear-gradient(135deg,#ff6b6b,#ee5a52);border-radius:10px;color:#fff;display:flex;font-size:.9rem;gap:10px;padding:12px 15px}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}.error-message i,.login-btn{font-size:1.1rem}.login-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:10px;justify-content:center;margin-top:10px;overflow:hidden;padding:15px 20px;position:relative;transition:all .3s ease}.login-btn:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;width:100%}.login-btn:hover:before{left:100%}.login-btn:hover{box-shadow:0 10px 25px #667eea4d;transform:translateY(-2px)}.login-btn:active{transform:translateY(0)}.login-btn:disabled{cursor:not-allowed;opacity:.7;transform:none}.login-btn.loading{pointer-events:none}.login-btn i.fa-spinner{animation:spin 1s linear infinite}.login-footer{border-top:1px solid #e9ecef;margin-top:25px;padding-top:20px;text-align:center}.login-footer p{color:#7f8c8d;font-size:.9rem;margin:0}.login-footer a{color:#667eea;font-weight:600;text-decoration:none;transition:color .3s ease}.login-footer a:hover{color:#764ba2;text-decoration:underline}@media (max-width:768px){.login-container{padding:15px}.login-card{max-width:100%;padding:30px 25px}.logo h1{font-size:2rem}.login-header h2{font-size:1.5rem}.bg-shape{display:none}}@media (max-width:480px){.login-card{padding:25px 20px}.logo h1{font-size:1.8rem}.login-header h2{font-size:1.3rem}.input-wrapper input{padding:12px 12px 12px 40px}.login-btn{font-size:1rem;padding:12px 20px}}.navbar{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#607560,#cdc 50%,#e8ebe8);border-bottom:1px solid #ffffff1a;box-shadow:0 4px 20px #00000026,0 2px 8px #0000001a;color:#fff;display:flex;height:70px;justify-content:space-between;padding:0 2rem;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.navbar-brand h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#fff,#e2e8f0);-webkit-background-clip:text;background-clip:text;color:#fff;font-size:1.75rem;font-weight:800;letter-spacing:-.025em;margin:0}.navbar-menu{gap:1rem}.navbar-menu,.navbar-user{align-items:center;display:flex}.navbar-user{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;gap:.75rem;padding:.75rem 1rem;position:relative;transition:all .3s ease}.user-info{align-items:flex-end;display:flex;flex-direction:column;gap:.25rem}.user-name{color:#fff;font-size:.875rem;font-weight:600;line-height:1.2}.user-role{color:#ffffffb3;font-size:.75rem;font-weight:500;line-height:1.2}.user-avatar{align-items:center;background:linear-gradient(135deg,#607560,#cdc);border:2px solid #fff3;border-radius:50%;box-shadow:0 4px 12px #00000026;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:700;height:40px;justify-content:center;transition:all .3s ease;width:40px}.user-avatar:hover{border-color:#fff6;box-shadow:0 6px 20px #00000040;transform:scale(1.05)}.navbar-user:hover{background:#ffffff26;border-color:#fff3;box-shadow:0 4px 12px #0003;transform:translateY(-1px)}.user-dropdown{animation:dropdownFadeIn .2s ease-out;background:#fff;border:1px solid #0000001a;border-radius:12px;box-shadow:0 20px 40px #00000026,0 8px 16px #0000001a;min-width:280px;overflow:hidden;position:absolute;right:0;top:calc(100% + .5rem);z-index:1001}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.dropdown-header{background:linear-gradient(135deg,#607560,#cdc);gap:1rem;padding:1.5rem}.dropdown-avatar,.dropdown-header{align-items:center;color:#fff;display:flex}.dropdown-avatar{background:#fff3;border:2px solid #ffffff4d;border-radius:50%;flex-shrink:0;font-size:1.125rem;font-weight:700;height:50px;justify-content:center;width:50px}.dropdown-info{display:flex;flex:1 1;flex-direction:column;gap:.25rem}.dropdown-name{color:#fff;font-size:1rem;font-weight:600;line-height:1.2}.dropdown-email{color:#fffc;font-size:.875rem;line-height:1.2}.dropdown-role{color:#ffffffb3;font-size:.75rem;font-weight:500;letter-spacing:.05em;line-height:1.2;text-transform:uppercase}.dropdown-divider{background:#0000001a;height:1px;margin:0}.dropdown-actions{padding:.5rem 0}.dropdown-item{align-items:center;background:none;border:none;color:#374151;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.75rem;padding:.75rem 1.5rem;text-align:left;transition:all .2s ease;width:100%}.dropdown-item:hover{background:#f3f4f6;color:#1f2937}.dropdown-item.logout{border-top:1px solid #0000001a;color:#dc2626;margin-top:.5rem}.dropdown-item.logout:hover{background:#fef2f2;color:#b91c1c}.dropdown-item i{opacity:.7;text-align:center;width:16px}@media (max-width:768px){.navbar{padding:0 1rem}.navbar-brand h1{font-size:1.25rem}.user-name{display:none}}.sidebar{background:linear-gradient(180deg,#f6f7f6,#e8ebe8);border-right:1px solid #cdc;box-shadow:2px 0 10px #0000000d;display:flex;flex-direction:column;height:calc(100vh - 70px);left:0;overflow:visible;position:fixed;top:70px;transition:transform .3s ease;width:200px;z-index:999}.sidebar-content{flex:1 1;overflow-x:visible;overflow-y:auto}.sidebar-header{background:linear-gradient(135deg,#607560,#cdc);border-top:1px solid #cdc;color:#fff;margin-top:auto;padding:1.5rem}.sidebar-user{gap:.75rem}.sidebar-avatar,.sidebar-user{align-items:center;display:flex}.sidebar-avatar{background:#fff3;border:2px solid #ffffff4d;border-radius:50%;color:#fff;flex-shrink:0;font-size:.875rem;font-weight:700;height:45px;justify-content:center;width:45px}.sidebar-user-info{display:flex;flex:1 1;flex-direction:column;gap:.25rem;min-width:0}.sidebar-username{color:#fff;font-size:.875rem;font-weight:600;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-role{color:#fffc;font-size:.75rem;font-weight:500;letter-spacing:.05em;line-height:1.2;text-transform:uppercase}.sidebar-nav{flex:1 1;overflow-y:auto;padding:1rem 0}.sidebar-menu{list-style:none;margin:0;padding:0}.sidebar-item{margin-bottom:.25rem}.sidebar-link{align-items:center;border-radius:12px;border-right:3px solid #0000;color:#64748b;display:flex;margin:.25rem .75rem;padding:1rem 1.5rem;position:relative;text-decoration:none;transition:all .3s ease}.sidebar-link:hover{background:linear-gradient(135deg,#f6f7f6,#cdc);box-shadow:0 2px 8px #0000001a;color:#565;transform:translateX(4px)}.sidebar-link.active{background:linear-gradient(135deg,#cdc,#cdc);border-right-color:#0000;box-shadow:0 4px 12px #565;color:#000;font-weight:600}.sidebar-link.active:before{background:linear-gradient(135deg,#565,#565);border-radius:2px;content:"";height:60%;left:-.75rem;position:absolute;top:50%;transform:translateY(-50%);width:4px}.sidebar-icon{font-size:1.5rem;margin-right:1rem;text-align:center;transition:transform .3s ease;width:28px}.sidebar-link:hover .sidebar-icon{transform:scale(1.1)}.sidebar-text{font-size:.9rem;font-weight:500;letter-spacing:.025em}@media (max-width:768px){.sidebar{transform:translateX(-100%);width:280px}.sidebar.open{transform:translateX(0)}.sidebar-overlay{background:#00000080;bottom:0;display:none;left:0;position:fixed;right:0;top:0;z-index:998}.sidebar-overlay.show{display:block}}.sidebar-content::-webkit-scrollbar{width:4px}.sidebar-content::-webkit-scrollbar-track{background:#0000}.sidebar-content::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:2px}.sidebar-content::-webkit-scrollbar-thumb:hover{background:#94a3b8}.sidebar-avatar{cursor:pointer;transition:all .2s ease}.sidebar-avatar:hover{box-shadow:0 4px 12px #0003;transform:scale(1.05)}.sidebar-user{position:relative}.sidebar-dropdown{animation:sidebarDropdownFadeIn .2s ease-out;background:#fff;border:1px solid #0000001a;border-radius:12px;bottom:calc(100% + .5rem);box-shadow:0 20px 40px #00000026,0 8px 16px #0000001a;left:100%;margin-left:.5rem;min-width:280px;overflow:hidden;position:absolute;width:280px;z-index:1001}@keyframes sidebarDropdownFadeIn{0%{opacity:0;transform:translateY(10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.sidebar-dropdown .dropdown-header{align-items:center;background:linear-gradient(135deg,#607560,#cdc);color:#fff;display:flex;gap:1rem;padding:1.5rem}.sidebar-dropdown .dropdown-avatar{align-items:center;background:#fff3;border:2px solid #ffffff4d;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:1.125rem;font-weight:700;height:50px;justify-content:center;width:50px}.sidebar-dropdown .dropdown-info{display:flex;flex:1 1;flex-direction:column;gap:.25rem}.sidebar-dropdown .dropdown-name{color:#fff;font-size:1rem;font-weight:600;line-height:1.2}.sidebar-dropdown .dropdown-email{color:#fffc;font-size:.875rem;line-height:1.2}.sidebar-dropdown .dropdown-role{color:#ffffffb3;font-size:.75rem;font-weight:500;letter-spacing:.05em;line-height:1.2;text-transform:uppercase}.sidebar-dropdown .dropdown-divider{background:#0000001a;height:1px;margin:0}.sidebar-dropdown .dropdown-actions{padding:.5rem 0}.sidebar-dropdown .dropdown-item{align-items:center;background:none;border:none;color:#374151;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.75rem;padding:.75rem 1.5rem;text-align:left;transition:all .2s ease;width:100%}.sidebar-dropdown .dropdown-item:hover{background:#f3f4f6;color:#111827}.sidebar-dropdown .dropdown-item.logout{color:#dc2626}.sidebar-dropdown .dropdown-item.logout:hover{background:#fef2f2;color:#b91c1c}.sidebar-dropdown .dropdown-item i{align-items:center;display:flex;font-size:.875rem;height:16px;justify-content:center;width:16px}.dashboard{background:linear-gradient(135deg,#f6f7f6,#e8ebe8);min-height:100vh}.dashboard-main{margin:0 auto;max-width:1400px;padding:2rem}.welcome-section{background:#fff;border:1px solid #fff3;border-radius:20px;box-shadow:0 10px 30px #0000001a;margin-bottom:2rem;padding:2rem}.welcome-content h2{color:#2d3748;font-size:2rem;font-weight:700;margin-bottom:.5rem}.welcome-content p{color:#718096;font-size:1.125rem;margin-bottom:1rem}.current-time{align-items:center;background:#f7fafc;border-left:4px solid #667eea;border-radius:10px;color:#4a5568;display:flex;font-weight:500;gap:.5rem;padding:.75rem 1rem}.current-time i{color:#667eea}.stats-section{margin-bottom:2rem}.stats-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:3rem}.stat-card{align-items:center;background:linear-gradient(135deg,#fff,#fafbfc);border:1px solid #e2e8f080;border-radius:20px;box-shadow:0 8px 32px #00000014,0 4px 16px #0000000a;display:flex;gap:1.5rem;overflow:hidden;padding:2rem;position:relative;transition:all .4s ease}.stat-card:before{background:linear-gradient(135deg,var(--primary-color) 0,var(--primary-dark) 100%);content:"";height:4px;left:0;position:absolute;right:0;top:0}.stat-card:hover{box-shadow:0 20px 40px #00000026,0 8px 24px #0000001a;transform:translateY(-8px) scale(1.02)}.stat-card.blue:before{background:linear-gradient(135deg,var(--primary-color) 0,#1e40af 100%)}.stat-card.green:before{background:linear-gradient(135deg,var(--success-color) 0,#059669 100%)}.stat-card.purple:before{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.stat-card.orange:before{background:linear-gradient(135deg,var(--warning-color) 0,#d97706 100%)}.stat-icon{align-items:center;background:linear-gradient(135deg,var(--light-gray) 0,#f1f5f9 100%);border-radius:20px;box-shadow:0 4px 12px #0000001a;display:flex;font-size:2.5rem;height:80px;justify-content:center;transition:all .3s ease;width:80px}.stat-card:hover .stat-icon{box-shadow:0 6px 20px #00000026;transform:scale(1.1) rotate(5deg)}.stat-content{flex:1 1}.stat-title{color:var(--secondary-color);font-size:.9rem;font-weight:600;letter-spacing:.1em;line-height:1.2;margin:0 0 .75rem;text-transform:uppercase}.stat-value{-webkit-text-fill-color:#0000;align-items:center;background:linear-gradient(135deg,var(--dark-gray) 0,var(--secondary-color) 100%);-webkit-background-clip:text;background-clip:text;display:flex;font-size:2.5rem;font-weight:800;letter-spacing:-.025em;margin:0}.dashboard-content{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:1fr 1fr}.dashboard-section{background:linear-gradient(135deg,#fff,#fafbfc);border:1px solid #e2e8f080;border-radius:20px;box-shadow:0 8px 32px #00000014,0 4px 16px #0000000a;min-height:400px;padding:2rem;transition:all .3s ease}.dashboard-section:hover{box-shadow:0 16px 40px #0000001f,0 8px 24px #00000014;transform:translateY(-4px)}.quick-actions{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.quick-actions .btn{align-items:center;border-radius:16px;display:flex;flex-direction:column;font-weight:600;gap:1rem;overflow:hidden;padding:1.5rem;position:relative;text-align:center;text-decoration:none;transition:all .3s ease}.quick-actions .btn:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.quick-actions .btn:hover:before{left:100%}.quick-actions .btn:hover{transform:translateY(-4px) scale(1.05)}.quick-actions .btn span{font-size:2rem;transition:all .3s ease}.quick-actions .btn:hover span{transform:scale(1.1)}.activity-list{display:flex;flex-direction:column;gap:1.5rem;max-height:400px;overflow-y:auto;padding-right:.5rem}.activity-list::-webkit-scrollbar{width:6px}.activity-list::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.activity-list::-webkit-scrollbar-thumb{background:linear-gradient(135deg,var(--primary-color) 0,var(--primary-dark) 100%);border-radius:3px}.activity-item{align-items:flex-start;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f080;border-radius:16px;display:flex;gap:1.5rem;padding:1.5rem;position:relative;transition:all .3s ease}.activity-item:before{background:linear-gradient(135deg,var(--primary-color) 0,var(--primary-dark) 100%);border-radius:0 2px 2px 0;bottom:0;content:"";left:0;opacity:0;position:absolute;top:0;transition:opacity .3s ease;width:4px}.activity-item:hover{background:linear-gradient(135deg,#fff,#f8fafc);box-shadow:0 8px 24px #0000001a;transform:translateX(8px)}.activity-item:hover:before{opacity:1}.activity-icon{align-items:center;border-radius:12px;box-shadow:0 4px 12px #00000026;color:#fff;display:flex;flex-shrink:0;font-size:1.25rem;font-weight:600;height:48px;justify-content:center;transition:all .3s ease;width:48px}.activity-item:hover .activity-icon{box-shadow:0 6px 20px #0003;transform:scale(1.1) rotate(5deg)}.activity-icon.green{background:linear-gradient(135deg,var(--success-color) 0,#059669 100%)}.activity-icon.blue{background:linear-gradient(135deg,var(--primary-color) 0,#1e40af 100%)}.activity-icon.purple{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.activity-content{flex:1 1}.activity-content p{color:var(--dark-gray);font-size:1rem;font-weight:600;line-height:1.5;margin:0 0 .5rem}.activity-time{color:var(--secondary-color);font-size:.8rem;font-weight:500;opacity:.8;transition:opacity .3s ease}.activity-item:hover .activity-time{opacity:1}.dashboard-loading{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:400px}.dashboard-loading .spinner{animation:spin 1s linear infinite;border:4px solid #3b82f61a;border-left:4px solid var(--primary-color);border-radius:50%;height:60px;width:60px}.dashboard-loading p{color:var(--secondary-color);font-size:1.1rem;font-weight:500}.quick-actions-section{margin-bottom:2rem}.quick-actions-section h3{border-left:4px solid #667eea;color:#2d3748;font-size:1.5rem;font-weight:700;margin-bottom:1.5rem;padding-left:1rem}.actions-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.action-card{align-items:center;background:#fff;border:1px solid #fff3;border-radius:15px;box-shadow:0 5px 15px #00000014;display:flex;gap:1rem;padding:1.5rem;transition:all .3s ease}.action-card,.action-card:hover{color:inherit;text-decoration:none}.action-card:hover{box-shadow:0 15px 35px #00000026;transform:translateY(-5px)}.action-card .card-icon{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:15px;color:#fff;display:flex;flex-shrink:0;font-size:1.5rem;height:60px;justify-content:center;width:60px}.action-card .card-content{flex:1 1}.action-card .card-content h4{color:#2d3748;font-size:1.125rem;font-weight:600;margin:0 0 .5rem}.action-card .card-content p{color:#718096;font-size:.875rem;line-height:1.4;margin:0}.action-card .card-arrow{color:#cbd5e0;font-size:1.25rem;transition:all .3s ease}.action-card:hover .card-arrow{color:#667eea;transform:translateX(5px)}.user-info-section{background:#fff;border:1px solid #fff3;border-radius:20px;box-shadow:0 10px 30px #0000001a;padding:2rem}.user-info-section h3{border-left:4px solid #667eea;color:#2d3748;font-size:1.5rem;font-weight:700;margin-bottom:1.5rem;padding-left:1rem}.info-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.info-card{background:#f7fafc;border-left:4px solid #e2e8f0;border-radius:10px;padding:1rem;transition:all .3s ease}.info-card:hover{border-left-color:#667eea;transform:translateX(5px)}.info-label{color:#4a5568;font-size:.875rem;font-weight:600;letter-spacing:.05em;margin-bottom:.5rem;text-transform:uppercase}.info-value{color:#2d3748;font-size:1rem;font-weight:500;word-break:break-word}@media (max-width:1024px){.dashboard-main{padding:1.5rem}.header-content{padding:0 1.5rem}.actions-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.info-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media (max-width:768px){.header-content{text-align:center}.header-content,.user-section{flex-direction:column;gap:1rem}.user-info{flex-direction:column;text-align:center}.dashboard-main{padding:1rem}.welcome-content h2{font-size:1.5rem}.actions-grid{grid-template-columns:1fr}.action-card{flex-direction:column;padding:2rem 1.5rem;text-align:center}.info-grid{grid-template-columns:1fr}}@media (max-width:480px){.logo-section h1{font-size:1.5rem}.user-info-section,.welcome-section{padding:1.5rem}.current-time{font-size:.875rem;padding:.5rem .75rem}.dashboard-content{gap:2rem}.dashboard-section{padding:1.5rem}}@media (max-width:768px){.dashboard{padding:0 1rem}.dashboard-content{gap:2rem;grid-template-columns:1fr}.stats-grid{gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:2rem}.stat-card{padding:1.5rem}.stat-icon{height:60px;width:60px}.stat-icon,.stat-value{font-size:2rem}.quick-actions{gap:1rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.activity-item,.quick-actions .btn{padding:1.25rem}.activity-item{gap:1.25rem}.activity-icon{font-size:1.1rem;height:40px;width:40px}}@media (max-width:480px){.dashboard{padding:0 .75rem}.stats-grid{gap:1rem;grid-template-columns:1fr}.stat-card{gap:1.25rem;padding:1.25rem}.stat-icon{height:50px;width:50px}.stat-icon,.stat-value{font-size:1.75rem}.quick-actions{grid-template-columns:1fr}.dashboard-section{min-height:300px;padding:1.25rem}.activity-item{gap:1rem;padding:1rem}.activity-icon{font-size:1rem;height:36px;width:36px}.activity-content p{font-size:.9rem}}.terceros-list{margin:0 auto;max-width:1400px}.loading-container .spinner{height:40px;margin-bottom:1rem;width:40px}.loading-container p{color:var(--secondary-color)}.action-buttons{align-items:center;display:flex;gap:.5rem}.action-buttons .btn{font-size:.75rem;min-width:auto;padding:.25rem .5rem}.badge{border-radius:9999px;font-weight:500;padding:.25rem .75rem}.badge-success{background-color:#dcfce7}.badge-warning{background-color:#fef3c7}.badge-danger{background-color:#fee2e2}.badge-info{background-color:#dbeafe}.pagination{box-shadow:var(--shadow);gap:1rem;justify-content:center;padding:1.5rem}.pagination-info{color:var(--secondary-color);font-size:.875rem;font-weight:500}@media (max-width:1200px){.table-container{overflow-x:auto}.table{min-width:1000px}}@media (max-width:768px){.page-header{align-items:stretch;flex-direction:column}.page-header h1{font-size:1.5rem}.filters-section{padding:1rem}.search-box{align-items:stretch;flex-direction:column}.search-box .form-control{max-width:none}.filter-controls{align-items:stretch;flex-direction:column}.filter-controls .form-control{min-width:auto}.table td,.table th{font-size:.75rem;padding:.75rem .5rem}.action-buttons{flex-direction:column;gap:.25rem}.pagination{flex-direction:column;gap:.75rem}}@media (max-width:480px){.terceros-list{padding:0}.page-header{margin-bottom:1rem}.filters-section,.table-container{border-radius:0;margin-bottom:1rem}.pagination{border-radius:0}}.empty-state{color:var(--secondary-color);padding:3rem 2rem}.empty-state h3{color:var(--dark-gray);margin-bottom:.5rem}.empty-state p{margin-bottom:1.5rem}.status-indicator{align-items:center;display:inline-flex;gap:.5rem}.status-dot{background-color:var(--success-color);border-radius:50%;height:8px;width:8px}.status-dot.inactive{background-color:var(--danger-color)}.terceros-form{margin:0 auto;max-width:1200px;padding:2rem 1rem}.page-header{background:linear-gradient(#fff,#fff) padding-box,linear-gradient(135deg,var(--brand-dark) 0,var(--brand-medium) 100%) border-box;border-bottom:2px solid #0000;border-image:linear-gradient(135deg,var(--brand-dark) 0,var(--brand-medium) 100%) 1;padding-bottom:2rem;position:relative}.page-header:before{background:linear-gradient(135deg,var(--brand-dark) 0,var(--brand-medium) 100%);bottom:-2px;content:"";height:2px;left:0;position:absolute;right:0}.page-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--dark-gray) 0,var(--secondary-color) 100%);-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:800;letter-spacing:-.025em}.page-header p{font-size:1.1rem;font-weight:500;line-height:1.6}.tercero-form{display:flex;flex-direction:column;gap:2.5rem}.card{background:linear-gradient(135deg,#fff,#fafbfc);border:1px solid #e2e8f080;border-radius:20px;box-shadow:0 8px 32px #00000014,0 4px 16px #0000000a;position:relative}.card:before{background:linear-gradient(135deg,var(--primary-color) 0,var(--primary-dark) 100%);content:"";height:4px;left:0;position:absolute;right:0;top:0}.card:hover{box-shadow:0 16px 40px #0000001f,0 8px 24px #00000014;transform:translateY(-4px)}.card-header{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e2e8f080;padding:2rem}.card-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--dark-gray) 0,var(--secondary-color) 100%);-webkit-background-clip:text;background-clip:text}.card .form-group,.card .form-row{padding:0 2rem}.card .form-group:last-child,.card .form-row:last-child{padding-bottom:2rem}.card .form-group:first-of-type,.card .form-row:first-of-type{padding-top:2rem}.form-row{grid-gap:2rem;gap:2rem}.form-group,.form-row{margin-bottom:1.5rem}.form-label{font-size:.95rem;position:relative}.form-label:after{background:linear-gradient(135deg,var(--primary-color) 0,var(--primary-dark) 100%);border-radius:1px;bottom:-.25rem;height:2px;left:0;opacity:0;position:absolute;transition:opacity .3s ease;width:30px}.form-group:focus-within .form-label:after{opacity:1}.form-control{border:2px solid #e2e8f0cc;box-shadow:0 2px 8px #0000000a;font-size:1rem;font-weight:500;padding:1rem 1.25rem;position:relative}.form-control:focus{box-shadow:0 4px 20px #3b82f626,0 0 0 3px #3b82f61a;transform:translateY(-2px)}.form-control:hover{border-color:#3b82f666;box-shadow:0 4px 12px #00000014}.form-control:disabled{background:linear-gradient(135deg,#f8fafc,#f1f5f9);color:var(--secondary-color);opacity:.7}.form-control.is-invalid{background:linear-gradient(135deg,#fef2f2,#fef7f7)}.form-control.is-invalid:focus{box-shadow:0 4px 20px #ef444426,0 0 0 3px #ef44441a;transform:translateY(-2px)}.invalid-feedback{align-items:center;background:linear-gradient(135deg,#fef2f2,#fef7f7);border-left:3px solid var(--danger-color);border-radius:8px;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;margin-top:.5rem;padding:.5rem .75rem}.invalid-feedback:before{content:"⚠";font-size:1rem}.form-actions{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:0 0 20px 20px;border-top:1px solid #e2e8f080;gap:1.5rem;margin:0 -1px -1px;padding:2rem}@media (max-width:768px){.terceros-form{padding:var(--spacing-md)}.page-header{align-items:stretch;flex-direction:column;gap:var(--spacing-md)}.page-header h1{font-size:1.75rem}.form-row{gap:0;grid-template-columns:1fr}.card .form-group,.card .form-row{padding:0 var(--spacing-md)}.card .form-group:last-child,.card .form-row:last-child{padding-bottom:var(--spacing-md)}.card .form-group:first-of-type,.card .form-row:first-of-type{padding-top:var(--spacing-md)}.card-header{padding:var(--spacing-md)}.form-actions{flex-direction:column;gap:var(--spacing-sm)}.btn{width:100%}}@media (max-width:480px){.terceros-form{padding:var(--spacing-sm)}.page-header h1{font-size:1.5rem}.card-title{font-size:1.1rem}}.productos-list{margin:0 auto;max-width:1400px}.page-header{gap:1rem;margin-bottom:3rem}.page-header h1{color:var(--dark-gray);font-weight:700;margin:0 0 .5rem}.page-header p{color:var(--secondary-color)}.filters-section{background:linear-gradient(135deg,var(--brand-lightest) 0,#fff 100%);border:1px solid var(--brand-medium);border-radius:var(--border-radius);box-shadow:var(--shadow);display:flex;flex-direction:column;gap:1rem;margin-bottom:3rem;padding:1.5rem}.search-box{align-items:center;display:flex;gap:1rem}.search-box .form-control{flex:1 1;max-width:400px}.filter-controls{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.filter-controls .form-control{min-width:200px;width:auto}.checkbox-container{align-items:center;display:flex}.checkbox-label{color:var(--dark-gray);font-size:.9rem;gap:.5rem;margin:0}.checkbox-input{accent-color:var(--primary-color);cursor:pointer;height:18px;width:18px}.checkbox-text{font-weight:500}.checkbox-label:hover .checkbox-text{color:var(--primary-color)}.loading-container{background:#fff;border-radius:var(--border-radius);box-shadow:var(--shadow);padding:4rem 2rem}.spinner{border-top:3px solid var(--border-color);border:3px solid var(--border-color);height:32px;margin-bottom:var(--spacing-lg);width:32px}.table-container{background:#fff;border-radius:var(--border-radius);box-shadow:var(--shadow);margin-bottom:2rem;overflow:hidden}.table th{background:var(--light-gray);border-bottom:2px solid var(--medium-gray);font-weight:600;padding:1rem .75rem;text-align:left}.table td{border-bottom:1px solid var(--medium-gray);padding:1rem .75rem;vertical-align:middle}.table tbody tr{transition:background-color .2s ease}.table tbody tr:hover{background-color:var(--light-gray)}.table tbody tr:last-child td{border-bottom:none}.productos-table{border-collapse:collapse;font-size:.9rem;width:100%}.productos-table th{background:var(--bg-light);color:var(--text-primary);font-weight:600;text-align:left;white-space:nowrap}.productos-table td,.productos-table th{border-bottom:1px solid var(--border-color);padding:var(--spacing-md)}.productos-table td{vertical-align:top}.productos-table tbody tr{transition:background-color .2s ease}.productos-table tbody tr:hover{background-color:var(--bg-light)}.productos-table tbody tr.inactive-row{background-color:#f9f9f9;opacity:.6}.productos-table tbody tr:last-child td{border-bottom:none}.codigo{background:#3b82f61a;border-radius:4px;color:var(--primary-color);font-family:Courier New,monospace;font-size:.85rem;font-weight:600;padding:2px 6px}.producto-info{display:flex;flex-direction:column;gap:2px}.producto-info .nombre{color:var(--text-primary);font-weight:500;line-height:1.3}.producto-info .descripcion{line-height:1.3;max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.categoria,.producto-info .descripcion{color:var(--text-secondary);font-size:.85rem}.categoria{background:var(--bg-light);border-radius:var(--border-radius-sm);font-weight:500;padding:4px 8px}.proveedor{color:var(--text-primary);font-weight:500}.precio{color:var(--success-color);font-size:.95rem;font-weight:600}.status-badge{border-radius:var(--border-radius-sm);font-size:.85rem;font-weight:500;padding:4px 8px}.status-badge.active{background:var(--success-light);color:var(--success-color)}.status-badge.inactive{background:var(--danger-light);color:var(--danger-color)}.actions{display:flex;gap:var(--spacing-xs);justify-content:flex-end}.btn-action{align-items:center;background:#0000;border:none;border-radius:var(--border-radius-sm);cursor:pointer;display:flex;font-size:.9rem;height:32px;justify-content:center;min-width:32px;padding:6px 8px;transition:all .2s ease}.btn-action:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn-edit{background:var(--primary-light);color:var(--primary-color)}.btn-edit:hover{background:var(--primary-color);color:#fff}.btn-activate{background:var(--success-light);color:var(--success-color)}.btn-activate:hover{background:var(--success-color);color:#fff}.btn-deactivate{background:var(--warning-light);color:var(--warning-color)}.btn-deactivate:hover{background:var(--warning-color);color:#fff}.btn-delete{background:var(--danger-light);color:var(--danger-color)}.btn-delete:hover{background:var(--danger-color);color:#fff}.pagination{align-items:center;border-radius:var(--border-radius);box-shadow:var(--shadow-sm);display:flex;justify-content:space-between;padding:var(--spacing-lg)}.pagination,.pagination-btn{background:#fff;border:1px solid var(--border-color)}.pagination-btn{border-radius:var(--border-radius-sm);color:var(--text-primary);cursor:pointer;font-size:.9rem;padding:var(--spacing-sm) var(--spacing-md);transition:all .2s ease}.pagination-btn:hover:not(:disabled){background:var(--primary-color);border-color:var(--primary-color);color:#fff}.pagination-btn:disabled{cursor:not-allowed;opacity:.5}.pagination-info{color:var(--text-secondary);font-size:.9rem}.empty-state{background:#fff;border:1px solid var(--border-color);border-radius:var(--border-radius);box-shadow:var(--shadow-sm);padding:var(--spacing-xxl);text-align:center}.empty-icon{font-size:4rem;margin-bottom:var(--spacing-lg);opacity:.5}.empty-state h3{color:var(--text-primary);font-size:1.5rem;margin:0 0 var(--spacing-md) 0}.empty-state p{color:var(--text-secondary);font-size:1rem;margin:0 0 var(--spacing-lg) 0;margin-left:auto;margin-right:auto;max-width:400px}.btn-primary:hover{background:var(--primary-dark);border-color:var(--primary-dark);box-shadow:var(--shadow-md);color:#fff;text-decoration:none;transform:translateY(-1px)}@media (max-width:1200px){.productos-table{font-size:.85rem}.productos-table td,.productos-table th{padding:var(--spacing-sm)}.producto-info .descripcion{max-width:200px}}@media (max-width:992px){.table-container{overflow-x:auto}.productos-table{min-width:800px}.filters{align-items:stretch;flex-direction:column;gap:var(--spacing-md)}.filter-select{min-width:auto}}@media (max-width:768px){.productos-list{padding:var(--spacing-md)}.page-header{align-items:stretch;flex-direction:column;gap:var(--spacing-md)}.page-header h1{font-size:1.75rem}.filters-section{padding:var(--spacing-md)}.pagination{flex-direction:column;gap:var(--spacing-md)}.pagination-info{order:-1}}@media (max-width:480px){.productos-list{padding:var(--spacing-sm)}.page-header h1{font-size:1.5rem}.productos-table{font-size:.8rem}.actions{flex-direction:column;gap:2px}.btn-action{font-size:.8rem;height:28px;min-width:28px}}.btn-action:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.filter-select:focus-visible,.search-input:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.table-container{transition:box-shadow .2s ease}.table-container:hover{box-shadow:var(--shadow-md)}.filters-section{transition:box-shadow .2s ease}.filters-section:hover{box-shadow:var(--shadow-md)}.productos-form{margin:0 auto;max-width:1000px;padding:var(--spacing-lg)}.page-header{align-items:flex-start;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:10px;padding-bottom:var(--spacing-lg)}.page-header h1{color:var(--text-primary);font-size:2rem;font-weight:600;margin:0 0 var(--spacing-xs) 0}.page-header p{color:var(--text-secondary);font-size:.95rem;margin:0}.producto-form{display:flex;flex-direction:column;gap:var(--spacing-xl)}.card{background:#fff;border:1px solid var(--border-color);border-radius:var(--border-radius);box-shadow:var(--shadow-sm);overflow:hidden}.card-header{background:var(--bg-light);border-bottom:1px solid var(--border-color);padding:var(--spacing-lg)}.card-title{color:var(--text-primary);font-size:1.25rem;font-weight:600;margin:0}.card .form-group,.card .form-row{padding:0 var(--spacing-lg)}.card .form-group:last-child,.card .form-row:last-child{padding-bottom:var(--spacing-lg)}.card .form-group:first-of-type,.card .form-row:first-of-type{padding-top:var(--spacing-lg)}.form-row{grid-gap:var(--spacing-lg);gap:var(--spacing-lg);grid-template-columns:1fr 1fr}.form-group,.form-row{margin-bottom:var(--spacing-lg)}.form-label{color:var(--text-primary);font-weight:500;margin-bottom:var(--spacing-xs)}.form-control{background:#fff;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);font-size:.95rem;padding:var(--spacing-sm) var(--spacing-md);transition:all .2s ease}.form-control:focus{box-shadow:0 0 0 3px #3b82f61a}.form-control:disabled{background-color:var(--bg-light);color:var(--text-secondary);cursor:not-allowed}.form-control.is-invalid:focus{border-color:var(--danger-color);box-shadow:0 0 0 3px #ef44441a}textarea.form-control{min-height:80px;resize:vertical}.form-text,.invalid-feedback{font-size:.85rem;margin-top:var(--spacing-xs)}.form-text{color:var(--text-secondary)}.input-group{align-items:center;display:flex;position:relative}.input-group .form-control{flex:1 1}.input-prefix,.input-suffix{background:var(--bg-light);border:1px solid var(--border-color);color:var(--text-secondary);font-size:.95rem;font-weight:500;padding:var(--spacing-sm) var(--spacing-md);white-space:nowrap}.input-prefix{border-radius:var(--border-radius-sm) 0 0 var(--border-radius-sm);border-right:none}.input-suffix{border-left:none;border-radius:0 var(--border-radius-sm) var(--border-radius-sm) 0}.input-group .form-control{border-radius:0}.input-group .form-control:first-child{border-radius:var(--border-radius-sm) 0 0 var(--border-radius-sm)}.input-group .form-control:last-child{border-radius:0 var(--border-radius-sm) var(--border-radius-sm) 0}.input-group:has(.input-prefix) .form-control{border-left:none}.input-group:has(.input-suffix) .form-control{border-right:none}.btn-generate{background:var(--primary-color);border:1px solid var(--primary-color);border-left:none;border-radius:0 var(--border-radius-sm) var(--border-radius-sm) 0;color:#fff;cursor:pointer;font-size:1rem;padding:var(--spacing-sm) var(--spacing-md);transition:all .2s ease}.btn-generate:hover{background:var(--primary-dark);border-color:var(--primary-dark)}.checkbox-label{align-items:center;color:var(--text-primary);cursor:pointer;display:flex;font-size:.95rem;font-weight:500;gap:var(--spacing-xs);-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{cursor:pointer;height:16px;margin:0;width:16px}.form-actions{border-top:1px solid var(--border-color);gap:var(--spacing-md);margin-top:var(--spacing-lg);padding:var(--spacing-xl) 0}.btn{border:1px solid #0000;border-radius:var(--border-radius-sm);font-size:.95rem;font-weight:500;gap:var(--spacing-xs);min-width:120px;padding:var(--spacing-sm) var(--spacing-lg);transition:all .2s ease}.btn:disabled{opacity:.6}.btn-primary{background:var(--primary-color);border-color:var(--primary-color)}.btn-primary:hover:not(:disabled){background:var(--primary-dark);border-color:var(--primary-dark);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-outline{background:#fff;border-color:var(--border-color);color:var(--text-secondary)}.btn-outline:hover:not(:disabled){background:var(--bg-light);border-color:var(--text-secondary);color:var(--text-primary)}.spinner{border:2px solid #0000;border-top-color:currentcolor;height:16px;width:16px}.loading-container{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:var(--spacing-xxl);text-align:center}.loading-container .spinner{border-width:3px;color:var(--primary-color);height:32px;margin-bottom:var(--spacing-lg);width:32px}.loading-container p{color:var(--text-secondary);font-size:1rem;margin:0}@media (max-width:768px){.productos-form{padding:var(--spacing-md)}.page-header{align-items:stretch;flex-direction:column;gap:var(--spacing-md)}.page-header h1{font-size:1.75rem}.form-row{gap:0;grid-template-columns:1fr}.card .form-group,.card .form-row{padding:0 var(--spacing-md)}.card .form-group:last-child,.card .form-row:last-child{padding-bottom:var(--spacing-md)}.card .form-group:first-of-type,.card .form-row:first-of-type{padding-top:var(--spacing-md)}.card-header{padding:var(--spacing-md)}.form-actions{flex-direction:column;gap:var(--spacing-sm)}.btn{width:100%}}@media (max-width:480px){.productos-form{padding:var(--spacing-sm)}.page-header h1{font-size:1.5rem}.card-title{font-size:1.1rem}.input-prefix,.input-suffix{font-size:.85rem;padding:var(--spacing-sm)}}.form-control:valid:not(:placeholder-shown){border-color:var(--success-color)}.form-control:valid:not(:placeholder-shown):focus{box-shadow:0 0 0 3px #22c55e1a}.fade-in{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.form-control:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.btn:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.btn-generate:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.form-label:after{content:""}.form-group:has(.form-control[required]) .form-label:after,.form-group:has(input[aria-required=true]) .form-label:after{color:var(--danger-color);content:" *"}.card{transition:box-shadow .2s ease}.card:hover{box-shadow:var(--shadow-md)}select.form-control{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:2.5rem}select.form-control:disabled{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%9ca3af' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e")}input[type=number].form-control{text-align:right}input[type=number].form-control::-webkit-inner-spin-button,input[type=number].form-control::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number].form-control{-moz-appearance:textfield}.input-group:hover .input-prefix,.input-group:hover .input-suffix{background:#3b82f60d;border-color:var(--primary-color)}.input-group:focus-within .input-prefix,.input-group:focus-within .input-suffix{background:#3b82f61a;border-color:var(--primary-color)}input[style*="text-transform: uppercase"]{font-family:Courier New,monospace;font-weight:600;letter-spacing:.5px}.modal-overlay{background:#00000059;inset:0;z-index:50}.modal-card{background:#fff;border-radius:12px;box-shadow:0 12px 24px #0000001f;display:flex;flex-direction:column;max-height:90vh;max-width:95vw;width:960px}.modal-header{border-bottom:1px solid #e5e7eb;padding:16px 20px}.modal-body{overflow-y:auto;padding:16px 20px}.close-btn{background:#0000;border:none;cursor:pointer;font-size:20px}.grid.two-cols{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr;margin-bottom:12px}.grid.three-cols{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr 1fr}.form-group{display:flex;flex-direction:column}.form-group label{font-weight:600;margin-bottom:6px}.form-group input,.form-group select{border:1px solid #d1d5dbf2;border-radius:8px;padding:10px 12px}.highlight input{background:#fff7ed;border-color:#f59e0b}.table-box{margin-top:12px}.table-box table{border-collapse:collapse;table-layout:fixed;width:100%}.table-box td,.table-box th{border:1px solid #e5e7eb;padding:8px}.table-box th{text-align:center}.table-box td:first-child{text-align:left}.table-box td:nth-child(2),.table-box td:nth-child(3),.table-box td:nth-child(4){text-align:right}.table-box input{border:1px solid #d1d5dbf2;border-radius:8px;padding:6px;text-align:right}.table-box td:nth-child(2) input,.table-box td:nth-child(3) input{box-sizing:border-box;width:50%}.provider-row td{background:#f8fafc;font-weight:600}.table-box col.col-detalle{width:50%}.table-box col.col-cantidad{width:12%}.table-box col.col-costo{width:18%}.table-box col.col-total{width:20%}.totals-right{display:flex;justify-content:flex-end;margin-top:16px}.totals-panel{width:340px}.totals-table{background:#fff;border:1px solid #e5e7eb;border-collapse:initial;border-radius:10px;border-spacing:0;overflow:hidden;width:100%}.totals-table td{border-top:1px solid #e5e7eb;padding:10px 12px}.totals-table tr:first-child td{border-top:none}.totals-table td.label{color:#374151;font-weight:600}.totals-table td.label.with-input{align-items:center;display:flex;gap:8px}.totals-table td.label.with-input input{border:1px solid #d1d5dbf2;border-radius:8px;padding:8px;width:80px}.totals-table td.value{font-weight:700;text-align:right}.totals-table tr.emphasize td{background:#f3f4f6}.modal-actions{border-top:1px solid #e5e7eb;display:flex;gap:8px;justify-content:flex-end;padding:16px 20px}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}.quote-container{background:#fff;border-radius:12px;box-shadow:0 12px 24px #00000014;margin:24px auto;max-width:1100px;padding:24px}.quote-header h2{margin:0 0 8px}.quote-header p{color:#6b7280;margin:0 0 16px}.quote-form .form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr);margin-bottom:16px}.quote-form .form-group{display:flex;flex-direction:column}.quote-form .form-group label{font-weight:600;margin-bottom:6px}.quote-form input[type=date],.quote-form input[type=number],.quote-form input[type=text],.quote-form select,.quote-form textarea{border:1px solid #e5e7eb;border-radius:8px;padding:10px 12px}.inline-field{display:flex;gap:8px}.btn-primary{background:#2563eb;border:none;border-radius:8px}.btn-primary,.btn-secondary{cursor:pointer;padding:10px 14px}.btn-secondary{background:#f3f4f6;border:1px solid #e5e7eb;border-radius:8px;color:#111827}.btn-danger{background:#dc2626;border:none;border-radius:8px;cursor:pointer;padding:10px 14px}.form-actions{display:flex;justify-content:flex-end;margin-top:20px}.switch{align-items:center;gap:8px}.quote-form .form-group.right{grid-column:3}.combo{position:relative}.combo-input{border:1px solid #e5e7eb;border-radius:8px;padding:10px 34px 10px 12px;width:100%}.combo-clear{background:#f3f4f6;border:1px solid #e5e7eb;border-radius:50%;cursor:pointer;height:24px;line-height:20px;position:absolute;right:8px;top:50%;transform:translateY(-50%);width:24px}.combo-list{background:#fff;border:1px solid #e5e7eb;border-radius:10px;box-shadow:0 8px 16px #00000014;left:0;max-height:240px;overflow:auto;position:absolute;right:0;top:calc(100% + 4px);z-index:10}.combo-item{cursor:pointer;padding:10px 12px}.combo-item:hover{background:#f9fafb}.combo-title{color:#111827;font-weight:600}.combo-sub{color:#6b7280;font-size:12px}.items-table{border:1px solid #e5e7eb;border-radius:10px;margin-bottom:16px;padding:12px}.items-table-inner{border-collapse:initial;border-spacing:0 8px;table-layout:fixed;width:100%}.items-table-inner th{color:#374151;font-weight:600;padding:0 8px 8px 0;text-align:left}.items-table-inner td{padding:0 8px 0 0;vertical-align:middle}.items-table-inner td:last-child,.items-table-inner th:last-child{padding-right:0}.items-table-inner input{width:100%}.items-table-inner .value-label,.items-table-inner input[type=number]{border:1px solid #e5e7eb;border-radius:8px;padding:10px 12px;text-align:right}.items-table-inner .value-label{background:#fff;display:block;width:100%}.items-table-inner col.col-producto{width:40%}.items-table-inner col.col-cantidad{width:12%}.items-table-inner col.col-total,.items-table-inner col.col-unitario{width:18%}.items-table-inner col.col-acciones{width:12%}.items-actions{margin-top:12px}.items-actions,.items-actions-cell{display:flex;justify-content:flex-start}.actions-group{align-items:center;display:inline-flex;gap:8px}.btn-desc{border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;padding:10px 14px}.btn-desc.empty{background:#fff7ed;border-color:#fdba74;color:#7c2d12}.btn-desc.filled{background:#ecfdf5;border-color:#6ee7b7;color:#065f46}.icon-btn{align-items:center;display:inline-flex;height:36px;justify-content:center;padding:0;width:36px}.icon-btn svg{height:18px;width:18px}.quote-detail{background:#fff;border-radius:12px;box-shadow:0 12px 24px #00000014;margin:24px auto;max-width:1100px;padding:24px}.quote-detail .header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.quote-detail .summary{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,1fr);margin-bottom:16px}.quote-detail .summary .card{border:1px solid #e5e7eb;border-radius:10px;padding:12px}.quote-detail .summary .card .card-value{color:#111827;font-weight:600;margin-top:6px}.quote-detail .summary .spacer{visibility:hidden}.quote-detail .card{border:1px solid #e5e7eb;border-radius:10px;padding:12px}.quote-detail .items-table{margin-top:10px}.quote-detail .table{table-layout:auto;width:100%}.quote-detail .table col.col-acciones{width:80px}.quote-detail .table td:last-child,.quote-detail .table th:last-child{padding-left:8px;padding-right:8px;text-align:center}.quote-detail .table th{text-align:center}.quote-detail .table tbody td:nth-child(2),.quote-detail .table tbody td:nth-child(3),.quote-detail .table tbody td:nth-child(4){text-align:right}.quote-detail .total-card{align-items:center;display:flex;justify-content:space-between;margin-top:12px;padding:10px 30px}.quote-detail .total-row{display:flex;justify-content:flex-end}.quote-detail .total-card .total-value{font-weight:700;margin-right:8px}.quote-detail .images{margin-top:20px}.quote-detail .images-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.quote-detail .thumb{border:1px solid #e5e7eb;border-radius:10px;display:flex;flex-direction:column;gap:6px;padding:8px}.quote-detail .thumb img{border-radius:8px;height:120px;object-fit:cover;width:100%}.quote-detail .conditions{margin-top:20px}.quote-detail .conditions h3{margin-bottom:8px}.quote-detail .cond-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,1fr)}.quote-detail .cond-item{border:1px solid #e5e7eb;border-radius:10px;display:flex;flex-direction:column;gap:4px;padding:12px}.quote-detail .cond-label{color:#6b7280;font-size:12px;letter-spacing:.2px;text-transform:uppercase}.quote-detail .cond-value{color:#111827;font-size:14px;font-weight:600}.modal-overlay{align-items:center;background:#0006;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 12px 24px #0000001f;max-width:90vw;padding:16px;width:640px}.modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.modal-body{color:#374151;white-space:pre-wrap}.btn-outline{background:#f3f4f6;border:1px solid #e5e7eb;border-radius:8px;color:#111827;cursor:pointer;padding:8px 12px}:root{--brand-dark:#607560;--brand-medium:#cdc;--brand-light:#e8ebe8;--brand-lightest:#f6f7f6;--primary-color:#607560;--primary-dark:#607560;--secondary-color:#64748b;--success-color:#10b981;--warning-color:#f59e0b;--danger-color:#ef4444;--light-gray:#e8ebe8;--medium-gray:#cdc;--dark-gray:#334155;--white:#fff;--shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;--border-radius:0.5rem;--transition:all 0.2s ease-in-out}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f6f7f6;color:#334155;color:var(--dark-gray);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.App{display:flex;flex-direction:column;min-height:100vh}.app-container{display:flex;flex:1 1}.main-content{background:linear-gradient(135deg,#f6f7f6,#e8ebe8);flex:1 1;margin-left:200px;min-height:calc(100vh - 70px);padding:2rem;transition:all .2s ease-in-out;transition:var(--transition)}@media (max-width:768px){.main-content{margin-left:0;padding:1rem}}.card{background:linear-gradient(135deg,#f6f7f6,#fff);background:linear-gradient(135deg,#f6f7f6 0,var(--white) 100%);border:1px solid #cdc;border-radius:16px;box-shadow:0 4px 20px #00000014,0 2px 8px #0000000a;margin-bottom:1.5rem;padding:2rem;transition:all .3s ease}.card:hover{box-shadow:0 8px 30px #0000001f,0 4px 12px #00000014;transform:translateY(-2px)}.card-header{border-bottom:2px solid #cdc;border-bottom:2px solid var(--medium-gray);margin-bottom:1.75rem;padding-bottom:1.25rem;position:relative}.card-header:after{background:linear-gradient(135deg,#607560,#607560);background:linear-gradient(135deg,var(--primary-color) 0,var(--primary-dark) 100%);border-radius:1px;bottom:-2px;content:"";height:2px;left:0;position:absolute;width:60px}.card-title{color:#334155;color:var(--dark-gray);font-size:1.5rem;font-weight:700;letter-spacing:-.025em}.btn{align-items:center;border:none;border-radius:12px;cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:600;gap:.5rem;justify-content:center;letter-spacing:.025em;overflow:hidden;padding:.75rem 1.5rem;position:relative;text-decoration:none;transition:all .3s ease}.btn:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.btn:hover:before{left:100%}.btn:disabled{cursor:not-allowed;opacity:.5}.btn:disabled:before{display:none}.btn-primary{background:linear-gradient(135deg,#607560,#607560);background:linear-gradient(135deg,var(--primary-color) 0,var(--primary-dark) 100%);box-shadow:0 4px 12px #2563eb4d;color:#fff;color:var(--white)}.btn-primary:hover:not(:disabled){box-shadow:0 6px 20px #2563eb66;transform:translateY(-2px)}.btn-secondary{background:linear-gradient(135deg,#64748b,#475569);background:linear-gradient(135deg,var(--secondary-color) 0,#475569 100%);box-shadow:0 4px 12px #64748b4d;color:#fff;color:var(--white)}.btn-secondary:hover:not(:disabled){box-shadow:0 6px 20px #64748b66;transform:translateY(-2px)}.btn-success{background:linear-gradient(135deg,#10b981,#059669);background:linear-gradient(135deg,var(--success-color) 0,#059669 100%);box-shadow:0 4px 12px #10b9814d;color:#fff;color:var(--white)}.btn-success:hover:not(:disabled){box-shadow:0 6px 20px #10b98166;transform:translateY(-2px)}.btn-warning{background:linear-gradient(135deg,#f59e0b,#d97706);background:linear-gradient(135deg,var(--warning-color) 0,#d97706 100%);box-shadow:0 4px 12px #f59e0b4d;color:#fff;color:var(--white)}.btn-warning:hover:not(:disabled){box-shadow:0 6px 20px #f59e0b66;transform:translateY(-2px)}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);background:linear-gradient(135deg,var(--danger-color) 0,#dc2626 100%);box-shadow:0 4px 12px #ef44444d;color:#fff;color:var(--white)}.btn-danger:hover:not(:disabled){box-shadow:0 6px 20px #ef444466;transform:translateY(-2px)}.btn-outline{background-color:initial;border:2px solid #cdc;border:2px solid var(--medium-gray);box-shadow:0 2px 8px #0000000d;color:#334155;color:var(--dark-gray)}.btn-outline:hover:not(:disabled){background:linear-gradient(135deg,#e8ebe8,#f1f5f9);background:linear-gradient(135deg,var(--light-gray) 0,#f1f5f9 100%);border-color:#607560;border-color:var(--primary-color);box-shadow:0 4px 12px #0000001a;color:#607560;color:var(--primary-color);transform:translateY(-1px)}.btn-sm{font-size:.75rem;padding:.25rem .75rem}.btn-lg{font-size:1rem;padding:.75rem 1.5rem}.form-group{margin-bottom:1.25rem}.form-label{color:#334155;color:var(--dark-gray);display:block;font-size:.9rem;font-weight:600;letter-spacing:.025em;margin-bottom:.75rem}.form-control{background:linear-gradient(135deg,#fff,#fafbfc);background:linear-gradient(135deg,var(--white) 0,#fafbfc 100%);border:2px solid #cdc;border:2px solid var(--medium-gray);border-radius:12px;box-shadow:0 2px 4px #00000005;font-size:.9rem;padding:.875rem 1rem;transition:all .3s ease;width:100%}.form-control:focus{background:#fff;background:var(--white);border-color:#607560;border-color:var(--primary-color);box-shadow:0 0 0 4px #2563eb1a,0 4px 12px #0000001a;outline:none;transform:translateY(-1px)}.form-control.is-invalid{border-color:#ef4444;border-color:var(--danger-color);box-shadow:0 0 0 4px #ef44441a}.invalid-feedback{color:#ef4444;color:var(--danger-color);display:block;font-size:.75rem;margin-top:.25rem}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.table-container{background:linear-gradient(135deg,#fff,#fafbfc);background:linear-gradient(135deg,var(--white) 0,#fafbfc 100%);border:1px solid #e2e8f080;border-radius:16px;box-shadow:0 4px 20px #00000014,0 2px 8px #0000000a;overflow-x:auto}.table{background:#0000;border-collapse:collapse;width:100%}.table td,.table th{border-bottom:1px solid #e2e8f099;padding:1rem 1.25rem;text-align:left;transition:all .3s ease}.table th{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:2px solid #607560;border-bottom:2px solid var(--primary-color);color:#334155;color:var(--dark-gray);font-size:.875rem;font-weight:700;letter-spacing:.05em;position:-webkit-sticky;position:sticky;text-transform:uppercase;top:0;z-index:10}.table tbody tr{transition:all .3s ease}.table tbody tr:hover{background:linear-gradient(135deg,#f8fafc,#f1f5f9);box-shadow:0 2px 8px #0000001a;transform:scale(1.01)}.table tbody tr:nth-child(2n){background:#f8fafc4d}.table tbody tr:nth-child(2n):hover{background:linear-gradient(135deg,#f8fafc,#f1f5f9)}.badge{align-items:center;border:1px solid #0000;border-radius:20px;box-shadow:0 2px 4px #0000001a;display:inline-flex;font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:.5rem .875rem;text-transform:uppercase;transition:all .3s ease}.badge:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-1px)}.badge-success{background:linear-gradient(135deg,#dcfce7,#bbf7d0);border-color:#22c55e;color:#166534}.badge-warning{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:#f59e0b;color:#92400e}.badge-danger{background:linear-gradient(135deg,#fee2e2,#fecaca);border-color:#ef4444;color:#991b1b}.badge-info{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-color:#3b82f6;color:#1e40af}.text-center{text-align:center}.text-right{text-align:right}.mb-0{margin-bottom:0}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:1rem}.mb-4{margin-bottom:1.5rem}.mb-5{margin-bottom:2rem}.mt-0{margin-top:0}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:1rem}.mt-4{margin-top:1.5rem}.mt-5{margin-top:2rem}.d-flex{display:flex}.justify-content-between{justify-content:space-between}.align-items-center{align-items:center}.gap-2{gap:.5rem}.gap-3{gap:1rem}.spinner{animation:spin 1s linear infinite;border:2px solid #cdc;border-top:2px solid #607560;border:2px solid var(--medium-gray);border-radius:50%;border-top-color:var(--primary-color);height:20px;width:20px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}
/*# sourceMappingURL=main.faa9233b.css.map*/