*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(180deg,#f8fafc,#f1f5f9);color:#1e293b;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-size:13px}#root{zoom:.85;min-height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#f1f5f9}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}: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)}}.layout{background:linear-gradient(180deg,#f8fafc,#f1f5f9);display:flex;min-height:100vh}.sidebar{background:#fff;border-right:1px solid #e2e8f0;bottom:0;display:flex;flex-direction:column;left:0;overflow-y:auto;position:fixed;top:0;transition:transform .2s ease;width:260px;z-index:1000}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:#0000}.sidebar::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.sidebar::-webkit-scrollbar-thumb:hover{background:#94a3b8}.sidebar-header{align-items:center;background:#fff;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;min-height:72px;padding:20px}.logo-container{flex:1 1;gap:12px}.logo-container,.logo-icon{align-items:center;display:flex}.logo-icon{background:linear-gradient(135deg,#6366f1,#4f46e5);border-radius:8px;box-shadow:0 1px 2px 0 #0000000d;color:#fff;flex-shrink:0;font-size:16px;font-weight:700;height:36px;justify-content:center;width:36px}.logo-text{color:#1e293b;font-size:20px;font-weight:600;letter-spacing:-.02em}.sidebar-close{background:#0000;border:none;border-radius:6px;color:#64748b;cursor:pointer;display:none;padding:8px;transition:all .2s}.sidebar-close:hover{background:#f1f5f9;color:#1e293b}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:4px;min-height:0;overflow-y:auto;padding:20px 16px}.nav-item{align-items:center;border:1px solid #0000;border-radius:6px;color:#64748b;display:flex;font-size:14px;font-weight:500;gap:12px;padding:10px 16px;text-decoration:none;transition:all .2s}.nav-item:hover{background:#f8fafc;border-color:#e2e8f0;color:#1e293b}.nav-item.active{background:#eef2ff;border-left:2px solid #6366f1;color:#6366f1;padding-left:14px}.nav-icon{align-items:center;display:flex;flex-shrink:0;font-size:18px;justify-content:center}.nav-label{flex:1 1}.menu-group{display:flex;flex-direction:column;gap:2px}.menu-group-header{align-items:center;border:1px solid #0000;border-radius:6px;color:#64748b;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:12px;padding:10px 16px;transition:all .2s}.menu-group-header:hover{background:#f8fafc;border-color:#e2e8f0;color:#1e293b}.expand-icon{align-items:center;color:#94a3b8;display:flex;margin-left:auto;transition:transform .2s}.menu-group-items{display:flex;flex-direction:column;gap:2px;margin-top:2px}.nav-item-child{font-size:13px;padding-left:48px}.main-content{display:flex;flex:1 1;flex-direction:column;margin-left:260px;transition:margin-left .2s ease}.main-content.without-sidebar{margin-left:0}.top-header{background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 2px 0 #0000000d;justify-content:space-between;padding:16px 24px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header-left,.top-header{align-items:center;display:flex}.header-left{flex:1 1;gap:16px}.menu-toggle{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:6px;color:#64748b;cursor:pointer;display:none;justify-content:center;padding:8px;transition:all .2s}.menu-toggle:hover{background:#f8fafc;border-color:#cbd5e1;color:#1e293b}.page-title{color:#1e293b;font-size:16px;font-weight:600;margin:0}.header-right{align-items:center;display:flex;gap:12px}.profile-dropdown{position:relative}.profile-button{background:#0000;border:none;cursor:pointer;padding:0}.profile-avatar{align-items:center;background:linear-gradient(135deg,#6366f1,#4f46e5);border:2px solid #eef2ff;border-radius:8px;color:#fff;display:flex;font-size:14px;font-weight:600;height:40px;justify-content:center;text-transform:uppercase;transition:all .2s;width:40px}.profile-button:hover .profile-avatar{box-shadow:0 4px 6px -1px #6366f133;transform:scale(1.05)}.dropdown-menu{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;min-width:220px;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);z-index:1001}.dropdown-header{background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:16px}.profile-info{display:flex;flex-direction:column;gap:4px}.user-name{color:#1e293b;font-size:14px}.user-role{color:#64748b;font-size:12px;text-transform:capitalize}.dropdown-divider{background:#e2e8f0;height:1px}.dropdown-item{align-items:center;background:#0000;border:none;color:#64748b;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:12px;padding:12px 16px;text-align:left;transition:all .2s;width:100%}.dropdown-item:hover{background:#f8fafc;color:#1e293b}.dropdown-item svg{font-size:16px}.logout-item{color:#ef4444}.logout-item:hover{background:#fef2f2;color:#dc2626}.page-content{flex:1 1;margin:0 auto;max-width:1600px;padding:24px;width:100%}.sidebar-overlay{display:none}@media (max-width:1024px){.page-title{font-size:14px}.page-content{padding:20px}}@media (max-width:768px){.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.sidebar-close{display:flex}.sidebar-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a66;bottom:0;display:block;left:0;position:fixed;right:0;top:0;z-index:999}.main-content{margin-left:0!important}.page-title{display:none}.top-header{padding:12px 16px}.page-content{padding:16px}.menu-toggle{display:flex;padding:10px}}@media (max-width:480px){.sidebar{width:280px}.logo-text{font-size:18px}.page-content{padding:12px}}@media (min-width:1440px){.page-content{padding:32px}}.login-page{align-items:center;background:#fff;display:flex;justify-content:center;min-height:100vh;padding:20px}.login-container{background:#fff;border:1px solid #0000000d;border-radius:16px;box-shadow:0 20px 40px #00000014,0 8px 16px #0000000a;max-width:450px;overflow:hidden;width:100%}.login-header{background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff;padding:40px 30px;text-align:center}.login-header h1{font-size:32px;font-weight:600;margin-bottom:8px}.login-header p{font-size:14px;margin:0;opacity:.9}.login-form-container{padding:40px 30px}.form-tabs{background:#f9fafb;border-bottom:1px solid #e5e7eb;border-radius:8px;display:flex;margin-bottom:30px;overflow:hidden}.tab{background:none;color:#6b7280;font-size:15px;padding:14px 20px;transition:all .3s ease}.tab.active{box-shadow:0 2px 4px #0000000d;color:#2563eb}.login-form .form-group{margin-bottom:24px}.login-form label{color:#374151;display:block;font-size:14px;font-weight:500;margin-bottom:8px}.login-form .form-control{background:#fff;border:1.5px solid #d1d5db;border-radius:8px;box-sizing:border-box;font-size:15px;padding:14px 16px;transition:all .3s ease;width:100%}.login-form .form-control:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.login-form .form-control:hover{border-color:#9ca3af}.btn-block{background:linear-gradient(135deg,#2563eb,#3b82f6);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-top:8px;padding:14px 20px;transition:all .3s ease;width:100%}.btn-block:hover{box-shadow:0 8px 16px #2563eb4d;transform:translateY(-1px)}.btn-block:active{transform:translateY(0)}.btn-block:disabled{box-shadow:none;cursor:not-allowed;opacity:.6;transform:none}.dashboard{margin:0 auto;max-width:1400px}.dashboard-subtitle{align-items:center;color:#64748b;display:flex;font-size:13px;gap:8px;margin-top:4px}.dashboard-status{margin-bottom:24px}.status-banner{align-items:center;border-radius:8px;display:flex;font-weight:500;gap:16px;padding:16px 20px}.status-banner.success{background:#f0fdf4;border:1px solid #86efac;color:#166534}.status-banner.warning{background:#fef3c7;border:1px solid #fbbf24;color:#92400e}.status-banner h3{font-size:16px;font-weight:600;margin:0}.status-banner p{font-size:13px;margin:4px 0 0;opacity:.9}.stats-grid{margin-bottom:30px}.stat-card{align-items:flex-start;border-left:4px solid #3b82f6;border-radius:8px;box-shadow:0 2px 4px #0000001a;transition:transform .3s ease,box-shadow .3s ease}.stat-card:hover{box-shadow:0 4px 8px #00000026}.stat-card.success{border-left-color:#10b981}.stat-card.warning{border-left-color:#f59e0b}.stat-card.error{border-left-color:#ef4444}.stat-content p{font-weight:500}.stat-subtitle{color:#94a3b8;display:block;font-size:12px;margin-top:4px}.trend{align-items:center;display:flex;font-size:11px;font-weight:600;gap:6px;margin-top:8px}.trend.up{color:#10b981}.trend.down{color:#ef4444}.dashboard-content{margin-top:30px}.dashboard-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr;margin-bottom:24px}.card{box-shadow:0 2px 4px #0000001a;padding:24px}.card-header{margin-bottom:20px}.card-header h3{font-weight:600;margin:0 0 4px}.card-subtitle{color:#94a3b8;font-size:12px}.inventory-breakdown{display:flex;flex-direction:column;gap:16px}.breakdown-item{gap:8px}.breakdown-bar{background:#f1f5f9;border-radius:4px;height:8px;overflow:hidden}.breakdown-fill{border-radius:4px;height:100%;transition:width .3s ease}.breakdown-fill.success{background:#10b981}.breakdown-fill.info{background:#3b82f6}.breakdown-fill.warning{background:#f59e0b}.breakdown-label{align-items:center;display:flex;font-size:13px;justify-content:space-between}.label-text{color:#64748b;font-weight:500}.label-value{color:#1e293b;font-weight:600}.action-list{display:flex;flex-direction:column;gap:12px}.action-item{align-items:flex-start;border-left:3px solid;border-radius:6px;display:flex;gap:12px;padding:12px}.action-item.urgent{background:#fef2f2;border-left-color:#ef4444;color:#991b1b}.action-item.warning{background:#fffbeb;border-left-color:#f59e0b;color:#92400e}.action-item.info{background:#eff6ff;border-left-color:#3b82f6;color:#1e40af}.action-item.success{background:#f0fdf4;border-left-color:#10b981;color:#166534}.action-item svg{flex-shrink:0;margin-top:2px}.action-item strong{display:block;font-size:13px;font-weight:600;margin-bottom:4px}.action-item p{font-size:12px;margin:0 0 8px;opacity:.9}.action-item a{color:inherit;font-size:12px;font-weight:600;text-decoration:none;transition:opacity .2s}.action-item a:hover{opacity:.7}.fichas-status{align-items:center;background:#f8fafc;border-radius:8px;display:flex;gap:16px;justify-content:space-around;margin:20px 0;padding:20px}.status-item{border-radius:8px;flex:1 1;padding:16px;text-align:center;transition:transform .2s}.status-item:hover{transform:translateY(-2px)}.status-item.pending{background:#fffbeb;border:1px solid #fbbf24}.status-item.approved{background:#f0fdf4;border:1px solid #86efac}.status-item.rejected{background:#fef2f2;border:1px solid #fca5a5}.status-number{display:block;font-size:32px;font-weight:700;margin-bottom:8px}.status-item.pending .status-number{color:#f59e0b}.status-item.approved .status-number{color:#10b981}.status-item.rejected .status-number{color:#ef4444}.status-label{color:#64748b;font-size:13px;font-weight:500}.quick-links{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr);margin-top:16px}.quick-link{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;color:#1e293b;display:flex;font-size:13px;font-weight:500;gap:12px;padding:12px 16px;text-decoration:none;transition:all .2s}.quick-link:hover{background:#eff6ff;border-color:#3b82f6;color:#3b82f6;transform:translateY(-2px)}.quick-link svg{font-size:18px}.spinner{border:4px solid #e2e8f0}@media (max-width:1024px){.dashboard-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}}@media (max-width:768px){.quick-links,.stats-grid{grid-template-columns:1fr}.fichas-status{flex-direction:column}}.inventory-form-container{background:#fff;border-radius:12px;margin:0 auto;max-width:900px;padding:24px}.form-header{border-bottom:2px solid #e2e8f0;margin-bottom:24px;padding-bottom:16px}.form-header h2{color:#1e293b;font-size:22px;font-weight:700}.folio-badge{background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:8px;box-shadow:0 2px 8px #3b82f64d;color:#fff;font-size:13px;font-weight:700;letter-spacing:.5px;padding:6px 14px}.tabs-container{border-bottom:2px solid #e2e8f0;gap:8px;margin-bottom:24px;overflow-x:auto}.tab{border-bottom:3px solid #0000;color:#64748b;font-size:14px;gap:8px;padding:12px 20px;transition:all .2s ease;white-space:nowrap}.tab:hover{background:#f8fafc;color:#1e293b}.tab.active{background:#eff6ff;border-bottom-color:#3b82f6;color:#3b82f6}.tab svg{font-size:16px}.tab-content{margin-bottom:20px}.tab-content h3{background:none;border-bottom:1px solid #e2e8f0;color:#334155;font-size:16px;font-weight:600;margin:24px 0 16px;padding-bottom:12px}.tab-content h3:first-child{margin-top:0}.inventory-form{width:100%}.form-content{padding-top:20px}.form-row{box-shadow:none;padding:0}.form-group,.form-row{border:none!important;outline:none}.form-group{margin-bottom:16px}.form-group label{margin-bottom:6px}.required{color:#dc2626;font-weight:700;margin-left:4px}.form-control{border:1.5px solid #cbd5e1}textarea.form-control{min-height:80px}select.form-control{padding-right:36px}.error{align-items:center;color:#dc2626;display:flex;font-size:12px;font-weight:500;gap:4px;margin-top:4px}.error:before{content:"⚠";font-size:14px}.help-text{align-items:center;color:#64748b;display:flex;font-size:12px;gap:4px;margin-top:4px}.checkbox-group{display:flex;flex-direction:column;gap:12px;margin-top:8px}.checkbox-label{align-items:center;border-radius:6px;cursor:pointer;display:flex;gap:10px;padding:8px;transition:background .2s}.checkbox-label:hover{background:#f8fafc}.checkbox-label input[type=checkbox]{accent-color:#3b82f6;cursor:pointer;height:18px;width:18px}.checkbox-label span{color:#475569;font-size:14px;font-weight:500}.admin-warning{align-items:center;background:linear-gradient(135deg,#fef3c7,#fde68a);border:1.5px solid #fbbf24;border-radius:10px;color:#92400e;display:flex;font-size:14px;font-weight:500;gap:12px;margin-bottom:20px;padding:14px 16px}.admin-warning svg{color:#f59e0b;flex-shrink:0;font-size:20px}.admin-warning p{margin:0}.form-actions{border-top:2px solid #e2e8f0;margin-top:32px;padding-top:24px}.btn-cancel,.btn-primary{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-family:inherit;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:12px 24px;transition:all .2s ease}.btn-cancel{background:#f1f5f9;border:1.5px solid #cbd5e1;color:#475569}.btn-cancel:hover:not(:disabled){background:#e2e8f0;border-color:#94a3b8;box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}.btn-cancel:disabled,.btn-primary:disabled{cursor:not-allowed;opacity:.5;transform:none}.btn-cancel svg,.btn-primary svg{font-size:16px}@media (max-width:768px){.inventory-form-container{padding:16px}.form-header{align-items:flex-start;flex-direction:column;gap:12px}.form-row{grid-template-columns:1fr}.tabs-container{-webkit-overflow-scrolling:touch;overflow-x:auto}.tab{flex-shrink:0}.form-actions{flex-direction:column-reverse}.btn-cancel,.btn-primary{width:100%}}@media (max-width:480px){.form-header h2{font-size:18px}.tab{font-size:13px;padding:10px 16px}.form-control{font-size:16px}}.form-header-with-tabs{border-bottom:1px solid #e5e7eb;margin:-24px -24px 0}.form-header-top{background:#fff;padding:20px 24px 16px}.form-title-section{align-items:center;display:flex;justify-content:space-between}.form-title-section h2{color:#1f2937;font-size:20px;font-weight:600;margin:0}.form-header-with-tabs .folio-badge{background:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;color:#2563eb;font-size:13px;font-weight:600;padding:4px 12px}.inventory-tabs{background:#f9fafb;border-bottom:2px solid #e5e7eb;display:flex;gap:0;padding:0}.inventory-tab{align-items:center;background:#0000;border:none;border-bottom:3px solid #0000;color:#6b7280;cursor:pointer;display:flex;flex:1 1;font-family:inherit;gap:10px;justify-content:center;padding:14px 20px;position:relative;transition:all .2s ease}.inventory-tab:hover{background:#f3f4f6;color:#374151}.inventory-tab.active{background:#fff;border-bottom-color:#2563eb;color:#2563eb;font-weight:600}.tab-icon{font-size:20px}.tab-content{align-items:flex-start;display:flex;flex-direction:column;gap:2px}.tab-title{font-size:14px;font-weight:600;letter-spacing:.3px}.tab-subtitle{font-size:11px;font-weight:400;opacity:.7}.info-banner{align-items:flex-start;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;display:flex;gap:12px;margin-bottom:20px;padding:12px 16px}.info-icon{flex-shrink:0;font-size:20px;line-height:1}.info-content{flex:1 1}.info-content strong{color:#1e40af;display:block;font-size:14px;margin-bottom:4px}.info-content p{color:#3730a3;font-size:13px;line-height:1.4;margin:0}@media (max-width:768px){.form-header-with-tabs{margin:-16px -16px 0}.form-header-top{padding:16px}.form-title-section{align-items:flex-start;flex-direction:column;gap:8px}.form-title-section h2{font-size:18px}.inventory-tab{padding:12px 16px}.tab-icon{font-size:18px}.tab-title{font-size:13px}.tab-subtitle{font-size:10px}.info-banner{gap:10px;padding:10px 12px}.info-icon{font-size:18px}.info-content strong{font-size:13px}.info-content p{font-size:12px}}.input-label{color:#374151;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.file-upload-wrapper{align-items:center;display:flex;gap:12px}.hidden-input{display:none}.custom-file-upload{align-items:center;background-color:#fff;border:1px solid #d1d5db;border-radius:6px;box-shadow:0 1px 2px #0000000d;color:#374151;cursor:pointer;display:inline-flex!important;flex-direction:row!important;flex-wrap:nowrap!important;font-size:14px;font-weight:500;gap:10px;justify-content:center;max-width:none!important;min-height:38px;padding:8px 16px;transition:all .2s ease;white-space:nowrap!important;width:auto!important}.custom-file-upload:hover{background-color:#f9fafb;border-color:#9ca3af;color:#1f2937}.upload-icon{color:#6b7280;display:block;font-size:16px!important;height:16px;line-height:1;margin:0;min-width:16px}.file-name-display{color:#6b7280;font-size:13px;font-style:italic}.image-previews-row{display:flex;gap:12px;margin-top:12px}.preview-thumb-container{background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;height:80px;overflow:hidden;position:relative;width:80px}.preview-thumb{height:100%;object-fit:cover;width:100%}.no-image-placeholder{align-items:center;background:#f9fafb;border:1px dashed #e5e7eb;border-radius:6px;color:#9ca3af;display:flex;font-size:12px;gap:6px;margin-top:12px;padding:8px 12px;width:-webkit-fit-content;width:fit-content}.section-container{padding:10px 0}.inventory-tab{font-size:13px;letter-spacing:.5px;text-transform:uppercase}.drawer-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a99;transition:all .3s ease;z-index:999}.drawer-panel{bottom:0;box-shadow:-4px 0 24px #00000026;max-width:90vw;right:0;transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);width:600px;z-index:1000}.drawer-panel.open{transform:translateX(0)}.drawer-header{background:linear-gradient(135deg,#f8fafc,#fff);border-bottom:2px solid #e2e8f0}.drawer-title svg{color:#3b82f6;flex-shrink:0;font-size:28px}.drawer-title h2{color:#1e293b;font-weight:700;line-height:1.2}.drawer-subtitle{color:#64748b;font-weight:500}.drawer-close{background:#f1f5f9;color:#64748b}.drawer-close svg{font-size:18px}.drawer-close:hover{background:#fee2e2;color:#ef4444;transform:scale(1.05)}.drawer-content::-webkit-scrollbar{width:8px}.drawer-content::-webkit-scrollbar-track{background:#f1f5f9}.drawer-content::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.drawer-content::-webkit-scrollbar-thumb:hover{background:#94a3b8}.drawer-section{margin-bottom:32px}.section-title{border-bottom:2px solid #e2e8f0;color:#334155}.section-title svg{color:#3b82f6}.folio-display{align-items:center;background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1.5px solid #3b82f6;border-radius:10px;display:flex;gap:12px;margin-bottom:16px;padding:16px}.folio-display svg{color:#3b82f6;flex-shrink:0;font-size:32px}.folio-label{color:#64748b;font-size:12px;font-weight:500;text-transform:uppercase}.folio-label,.folio-value{display:block;letter-spacing:.5px}.folio-value{color:#1e293b;font-size:18px;font-weight:700;margin-top:2px}.status-badge{border:1px solid;border-radius:6px;display:flex;font-size:12px;padding:6px 12px}.detail-grid{grid-template-columns:1fr 1fr}.detail-item{gap:6px}.detail-item.highlight{background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1.5px solid #fbbf24;border-radius:8px;grid-column:1/-1;padding:14px}.detail-label{color:#64748b}.detail-icon{color:#3b82f6;font-size:14px}.detail-value{color:#1e293b;font-size:14px;line-height:1.4}.detail-item.highlight .detail-value{color:#92400e;font-size:18px;font-weight:700}.detail-full{margin-top:12px}.detail-text{background:#f8fafc;border-left:3px solid #3b82f6;border-radius:6px;color:#475569;font-size:14px;line-height:1.6;margin:6px 0 0;padding:12px;white-space:pre-wrap}.inventory-types{display:flex;flex-wrap:wrap;gap:10px}.type-badge{align-items:center;border-radius:8px;display:flex;font-size:13px;font-weight:600;gap:6px;padding:8px 14px}.type-badge.official{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border:1.5px solid #3b82f6;color:#1e40af}.type-badge.local{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border:1.5px solid #10b981;color:#065f46}.type-badge.research{background:linear-gradient(135deg,#e0e7ff,#c7d2fe);border:1.5px solid #6366f1;color:#4338ca}.admin-section{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #fbbf24;border-radius:12px;padding:20px}.admin-section .section-title{border-bottom-color:#f59e0b}.admin-warning-small{background:#fff;border:1px solid #fbbf24;border-radius:6px;color:#92400e;font-size:12px;font-weight:600;margin-bottom:16px;padding:10px 12px;text-align:center}.drawer-footer{background:#f8fafc;border-top:2px solid #e2e8f0}.btn-drawer{font-family:inherit}.btn-edit{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 2px 8px #3b82f64d;color:#fff}.btn-edit:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 12px #3b82f666}.btn-delete{border:1.5px solid #ef4444;color:#dc2626}.btn-delete:hover{border-color:#dc2626;box-shadow:0 2px 8px #ef444433}@media (max-width:768px){.drawer-panel{max-width:100%;width:100%}.drawer-header{padding:16px}.drawer-title svg{font-size:24px}.drawer-title h2{font-size:18px}.drawer-content{padding:16px}.detail-grid{grid-template-columns:1fr}.drawer-footer{flex-direction:column;padding:16px}.btn-drawer{width:100%}.folio-display{padding:12px}.folio-display svg{font-size:24px}.folio-value{font-size:16px}}@media (max-width:480px){.drawer-section{margin-bottom:24px}.section-title{font-size:14px}.detail-label{font-size:11px}.detail-value{font-size:13px}}.image-gallery{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));margin-top:12px}.gallery-item{aspect-ratio:1;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;overflow:hidden;position:relative}.gallery-item img{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.gallery-item:hover img{transform:scale(1.05)}.lightbox-overlay{background:#0a0c14bf;inset:0;padding:24px;position:fixed;z-index:2000}.lightbox-content,.lightbox-overlay{align-items:center;display:flex;justify-content:center}.lightbox-content{background:#0000;max-height:90vh;max-width:1100px;position:relative;width:100%}.lightbox-img{border-radius:8px;box-shadow:0 8px 30px #02061799;max-height:90vh;max-width:100%;object-fit:contain}.lightbox-close,.lightbox-next,.lightbox-prev{align-items:center;background:#ffffffe6;border:none;border-radius:8px;box-shadow:0 6px 18px #02061759;cursor:pointer;display:flex;font-size:20px;height:44px;justify-content:center;position:absolute;width:44px}.lightbox-close{right:12px;top:12px}.lightbox-prev{left:12px}.lightbox-next{right:12px}@media (max-width:768px){.lightbox-close,.lightbox-next,.lightbox-prev{height:38px;width:38px}}.universal-skeleton-wrapper{background:#fff;padding:20px}.universal-skeleton-row{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;gap:16px;margin-bottom:16px;padding:12px 16px}.skeleton-bar{animation:shimmer 1.5s ease-in-out infinite;background:linear-gradient(90deg,#f0f0f0,#e8e8e8 20%,#f0f0f0 40%,#f0f0f0);background-size:200% 100%;border-radius:4px;height:18px}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@media (prefers-color-scheme:dark){.skeleton-bar{background:linear-gradient(90deg,#2a2a2a,#333 20%,#2a2a2a 40%,#2a2a2a)}}@media (prefers-reduced-motion:reduce){.skeleton-bar{animation:none;opacity:.6}}.inventory-container{margin:0 auto;max-width:1600px;padding:24px}.inventory-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:24px}.inventory-header h1{color:#1e293b;font-size:28px;font-weight:700;margin:0 0 8px}.inventory-subtitle{color:#64748b;font-size:14px;margin:0}.btn-filter,.btn-primary,.btn-secondary{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-family:inherit;font-size:14px;font-weight:600;gap:8px;padding:10px 18px;transition:all .2s}.btn-filter.active{background:#3b82f6;border-color:#3b82f6}.inventory-toolbar{align-items:center;display:flex;gap:12px;margin-bottom:20px}.search-bar{border:1.5px solid #cbd5e1}.search-bar svg{color:#94a3b8;font-size:16px}.toolbar-actions{display:flex;gap:8px}.filters-panel{animation:slideDown .3s ease-out;border:1.5px solid #e2e8f0}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.filters-panel h3{color:#334155;font-size:16px;font-weight:600;margin:0 0 16px}.filters-grid{grid-template-columns:repeat(3,1fr);margin-bottom:16px}.filter-group label{letter-spacing:.5px;text-transform:uppercase}.filter-group select{background:#fff;border:1.5px solid #cbd5e1;border-radius:8px;color:#1e293b;cursor:pointer;font-family:inherit;font-size:14px;padding:10px 12px;transition:all .2s}.filter-group select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.filter-checkboxes{background:#f8fafc;border-radius:8px;display:flex;gap:20px;margin-bottom:16px;padding:16px}.filter-checkboxes label{align-items:center;color:#475569;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px}.filter-checkboxes input[type=checkbox]{accent-color:#3b82f6;cursor:pointer;height:18px;width:18px}.btn-clear-filters{background:#f1f5f9;border:1.5px solid #cbd5e1;border-radius:8px;color:#475569;cursor:pointer;font-family:inherit;font-size:14px;font-weight:600;padding:10px 16px;transition:all .2s}.btn-clear-filters:hover{background:#e2e8f0}.error-banner{align-items:center;background:linear-gradient(135deg,#fee2e2,#fecaca);border:1.5px solid #ef4444;border-radius:10px;color:#991b1b;display:flex;font-weight:500;gap:12px;margin-bottom:20px;padding:14px 16px}.error-banner svg{flex-shrink:0;font-size:20px}.inventory-table-container{background:#fff;border:1.5px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px #0000000d;overflow:hidden}.inventory-table{border-collapse:collapse;width:100%}.inventory-table thead{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:2px solid #e2e8f0}.inventory-table th{color:#475569;font-size:12px;font-weight:700;letter-spacing:.5px;padding:14px 16px;text-align:left;text-transform:uppercase}.inventory-table tbody tr{border-bottom:1px solid #f1f5f9;transition:all .2s}.inventory-table tbody tr:hover{background:#f8fafc}.table-row-clickable{cursor:pointer}.inventory-table td{color:#334155;font-size:14px;padding:14px 16px}.folio-cell{background:#eff6ff;border-radius:4px;color:#3b82f6;font-family:Courier New,monospace;font-size:12px;font-weight:700;padding:4px 8px}.marca-modelo-cell{display:flex;flex-direction:column;gap:2px}.marca-modelo-cell strong{color:#1e293b;font-weight:600}.marca-modelo-cell small{color:#64748b;font-size:12px}.empty-state{color:#94a3b8;padding:60px 20px!important}.empty-state svg{font-size:48px}.empty-state p{font-weight:500}.action-buttons{justify-content:flex-start}.action-btn{border:1.5px solid;border-radius:8px;font-size:14px;height:36px;width:36px}.action-btn.view{background:#eff6ff;border-color:#60a5fa;color:#3b82f6}.action-btn.view:hover{background:#dbeafe;transform:scale(1.05)}.action-btn.edit{background:#fffbeb;border-color:#fbbf24;color:#f59e0b}.action-btn.edit:hover{background:#fef3c7;transform:scale(1.05)}.action-btn.delete{background:#fef2f2;border-color:#f87171;color:#ef4444}.action-btn.delete:hover{background:#fee2e2;transform:scale(1.05)}.modal-overlay{z-index:998}.modal-content{max-width:900px;min-width:900px;width:900px}.inventory-loading{align-items:center;color:#64748b;display:flex;flex-direction:column;justify-content:center;min-height:400px}.inventory-loading svg{color:#3b82f6;font-size:48px;margin-bottom:16px}.inventory-loading p{font-size:16px;font-weight:500}.spin{animation:spin 1s linear infinite}@media (max-width:1200px){.filters-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.inventory-container{padding:16px}.inventory-header{flex-direction:column;gap:16px}.header-actions{width:100%}.btn-primary,.btn-secondary{flex:1 1}.inventory-toolbar{flex-direction:column}.toolbar-actions{width:100%}.toolbar-actions button{flex:1 1}.filters-grid{grid-template-columns:1fr}.filter-checkboxes{flex-direction:column}.inventory-table-container{overflow-x:auto}.inventory-table{min-width:800px}}@media (max-width:480px){.inventory-header h1{font-size:22px}.action-buttons{flex-direction:column}.action-btn{height:32px;width:100%}}.drawer-overlay{background-color:#00000080;bottom:0;left:0;opacity:0;position:fixed;right:0;top:0;transition:opacity .3s ease,visibility .3s ease;visibility:hidden;z-index:998}.drawer-overlay.open{opacity:1;visibility:visible}.drawer-panel{background:#fff;box-shadow:-4px 0 20px #00000026;display:flex;flex-direction:column;height:100vh;max-width:500px;overflow:hidden;position:fixed;right:-500px;top:0;transition:right .3s cubic-bezier(.4,0,.2,1);width:100%;z-index:999}.drawer-panel.open{right:0}.drawer-header{background:#764ba2;color:#fff;flex-shrink:0;justify-content:space-between;padding:24px}.drawer-header,.drawer-title{align-items:center;display:flex}.drawer-title{flex:1 1;gap:16px}.drawer-avatar{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border-radius:12px;display:flex;font-size:24px;height:56px;justify-content:center;width:56px}.drawer-title h2{color:#fff;font-size:20px;font-weight:600;line-height:1.3;margin:0}.drawer-subtitle{color:#fff;font-size:14px;font-weight:400;margin:4px 0 0;opacity:1}.drawer-close{align-items:center;background:#fff3;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:18px;height:36px;justify-content:center;transition:all .2s;width:36px}.drawer-close:hover{background:#ffffff4d;transform:rotate(90deg)}.drawer-content{flex:1 1;overflow-y:auto;padding:24px}.drawer-section{margin-bottom:28px}.drawer-section:last-child{margin-bottom:0}.section-title{align-items:center;border-bottom:2px solid #e5e7eb;color:#1f2937;display:flex;font-size:16px;font-weight:600;gap:10px;margin:0 0 16px;padding-bottom:8px}.section-title svg{color:#667eea;font-size:18px}.badges-row{display:flex;flex-wrap:wrap;gap:8px}.status-badge{align-items:center;background:#f3f4f6;border-radius:20px;color:#6b7280;display:inline-flex;font-size:13px;font-weight:600;gap:6px;padding:8px 16px}.status-badge svg{font-size:14px}.status-badge.badge-active{background:#d1fae5;color:#10b981}.status-badge.badge-inactive{background:#fee2e2;color:#ef4444}.detail-grid{grid-template-columns:repeat(2,1fr)}.detail-label{align-items:center;color:#6b7280;display:flex;font-size:12px;font-weight:600;gap:6px;letter-spacing:.5px;text-transform:uppercase}.detail-icon{color:#9ca3af;font-size:12px}.detail-value{color:#1f2937;font-size:15px;font-weight:500;word-break:break-word}.drawer-footer{background:#f9fafb;border-top:1px solid #e5e7eb;display:flex;flex-shrink:0;gap:12px;padding:20px 24px}.btn-drawer{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;flex:1 1;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:12px 20px;transition:all .2s}.btn-drawer svg{font-size:16px}.btn-drawer.btn-edit{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-drawer.btn-edit:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.btn-drawer.btn-delete{background:#fff;border:2px solid #ef4444;color:#ef4444}.btn-drawer.btn-delete:hover{background:#ef4444;color:#fff}@media (max-width:768px){.drawer-panel{max-width:100%;right:-100%}.drawer-header{padding:20px 16px}.drawer-avatar{font-size:20px;height:48px;width:48px}.drawer-title h2{font-size:18px}.drawer-content{padding:20px 16px}.detail-grid{gap:12px;grid-template-columns:1fr}.drawer-footer{flex-direction:column;padding:16px}}.employees-container{margin:0 auto;max-width:1600px;padding:24px}.employees-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:24px}.employees-header h1{align-items:center;color:#1e293b;display:flex;font-size:28px;font-weight:700;gap:12px;margin:0 0 8px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.stat-icon.purple{background:linear-gradient(135deg,#a855f7,#9333ea)}.stat-content h3{font-size:28px}.stat-content p{font-size:13px}.employees-toolbar{display:flex;gap:12px;margin-bottom:20px}.filter-select{border:1.5px solid #e2e8f0;border-radius:10px;padding:12px 16px}.employees-content{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden}.data-table thead{background:#e2e8f0;border-bottom:2px solid #cbd5e1}.data-table th{color:#2d3748!important;font-weight:700}.employee-avatar{font-size:14px;height:36px;width:36px}.btn-icon{font-size:14px;height:32px;width:32px}.btn-view{background:#e0e7ff;color:#4f46e5}.btn-view:hover{background:#c7d2fe;transform:translateY(-1px)}.btn-edit{background:#dbeafe;color:#1e40af}.btn-edit:hover{background:#bfdbfe}.btn-delete{background:#fee2e2;color:#991b1b}.btn-delete:hover{background:#fecaca}.subtipo-text,.unidad-text{color:#475569;font-size:13px;font-weight:500}.empty-cell{color:#94a3b8;font-size:14px;padding:60px 20px!important;text-align:center}.loading-state{color:#64748b;padding:80px 20px;text-align:center}.spinner{border-top-color:#3b82f6;margin:0 auto 16px}.modal-overlay{background:#00000080}.modal-header h2{color:#1e293b;font-size:20px;font-weight:600}.modal-close:hover{background:#e2e8f0}.form-row{grid-gap:16px;gap:16px;margin-bottom:16px}.form-group label{font-size:13px;gap:6px}.form-group input,.form-group select{border:1.5px solid #e2e8f0;color:#1e293b;font-family:inherit;font-size:14px;padding:10px 12px;transition:all .2s}.btn-primary,.btn-secondary{display:flex;font-family:inherit;font-size:14px;font-weight:600;gap:8px;padding:10px 18px}@media (max-width:768px){.employees-container{padding:16px}.employees-header{flex-direction:column;gap:16px}.stats-grid{grid-template-columns:1fr}.employees-toolbar{flex-direction:column}.table-container{overflow-x:scroll}.data-table{min-width:800px}.form-row{grid-template-columns:1fr}}.import-modal{max-width:600px}.import-instructions{background:#eff6ff;border-left:4px solid #3b82f6;border-radius:8px;margin-bottom:24px;padding:16px}.import-instructions p{color:#1e40af;font-weight:600;margin:0 0 8px}.import-instructions ol{color:#475569;margin:8px 0 0;padding-left:20px}.import-instructions li{font-size:14px;margin-bottom:4px}.file-upload-zone{background:#f8fafc;border:2px dashed #cbd5e1;border-radius:12px;cursor:pointer;margin-bottom:20px;padding:40px 20px;text-align:center;transition:all .3s}.file-upload-zone.dragging{background:#eff6ff;border-color:#3b82f6}.upload-icon{color:#94a3b8;font-size:48px;margin-bottom:16px}.file-upload-zone p{color:#64748b;font-size:14px;margin:8px 0}.upload-or{color:#94a3b8;font-weight:600;margin:16px 0!important}.selected-file{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;color:#059669;display:inline-flex;font-weight:600;gap:8px;margin-top:16px;padding:12px 20px}.import-result{border-radius:12px;margin-top:20px;padding:20px}.import-result.success{background:#d1fae5;border:1px solid #10b981}.import-result.error{background:#fee2e2;border:1px solid #ef4444}.import-result h4{color:#1e293b;font-size:16px;margin:0 0 16px}.import-stats{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr);margin-bottom:16px}.import-stats .stat-item{background:#fff;border-radius:8px;font-size:14px;padding:12px}.import-stats .stat-item.success{border-left:4px solid #10b981}.import-stats .stat-item.error{border-left:4px solid #ef4444}.import-errors{background:#fff;border-radius:8px;margin-top:12px;padding:16px}.import-errors h5{color:#991b1b;font-size:14px;font-weight:600;margin:0 0 12px}.import-errors ul{margin:0;max-height:200px;overflow-y:auto;padding-left:20px}.import-errors li{color:#475569;font-size:13px;margin-bottom:6px}.btn-outline{align-items:center;border:1.5px solid #cbd5e1;border-radius:8px;color:#475569;cursor:pointer;display:flex;font-family:inherit;font-size:14px;font-weight:600;gap:8px;padding:10px 18px;transition:all .2s}.btn-outline:hover{background:#f8fafc;border-color:#94a3b8;transform:translateY(-1px)}.btn-info{align-items:center;background:linear-gradient(135deg,#06b6d4,#0891b2);border:none;border-radius:8px;box-shadow:0 2px 8px #06b6d44d;color:#fff;cursor:pointer;display:flex;font-family:inherit;font-size:14px;font-weight:600;gap:8px;padding:10px 18px;transition:all .2s}.btn-info:hover{background:linear-gradient(135deg,#0891b2,#0e7490);box-shadow:0 4px 12px #06b6d466;transform:translateY(-1px)}.btn-info:disabled,.btn-primary:disabled{cursor:not-allowed;opacity:.5;transform:none!important}.attendance-quincenal-container{margin:0 auto;max-width:1800px;padding:24px}.attendance-quincenal-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:24px}.attendance-quincenal-header h1{align-items:center;color:#1e293b;display:flex;font-size:28px;font-weight:700;gap:12px;margin:0 0 8px}.filter-select{border:2px solid #e2e8f0;color:#1e293b;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s}.filter-select:hover{border-color:#3b82f6}.filter-select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.btn-secondary{background:linear-gradient(135deg,#64748b,#475569);color:#fff}.attendance-filters{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:20px;padding:20px 24px}.filters-row{align-items:flex-end;display:flex;flex-wrap:wrap;gap:16px}.filter-group{gap:6px}.filter-input{border:1.5px solid #e2e8f0;border-radius:8px;color:#1e293b;font-size:14px;padding:10px 14px;transition:all .2s}.filter-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.filter-results{align-items:center;background:#f1f5f9;border-radius:8px;color:#475569;display:flex;font-size:13px;font-weight:600;padding:10px 16px;white-space:nowrap}.btn-sm{font-size:13px;padding:8px 16px}.filter-checkbox{align-items:center;display:flex;padding-top:20px}.filter-checkbox label{align-items:center;cursor:pointer;display:flex;gap:8px;-webkit-user-select:none;user-select:none}.filter-checkbox input[type=checkbox]{accent-color:#3b82f6;cursor:pointer;height:18px;width:18px}.attendance-legend{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;gap:32px;margin-bottom:24px;padding:20px}.legend-item{color:#475569;font-size:14px;font-weight:500}.legend-item svg{font-size:16px}.icon-asistio{color:#10b981}.icon-falta{color:#ef4444}.icon-empty,.icon-sin-registrar{color:#cbd5e1}.legend-note{color:#94a3b8;font-size:13px;margin:0 0 0 auto}.attendance-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden}.card-body{padding:0;position:relative}.table-container-quincenal{max-height:70vh}.table-container-quincenal.expanded{border-radius:12px;box-shadow:0 20px 60px #0000004d;left:6.5vw!important;max-height:90vh!important;overflow:auto;position:fixed!important;top:5vh!important;transform:none!important;width:105vw!important;z-index:1001}.table-container-quincenal.expanded .attendance-table-quincenal{height:100%;width:100%}.table-overlay{animation:fadeIn .2s ease;background:#000000b3;cursor:pointer;z-index:1000}.attendance-table-quincenal{font-size:13px;table-layout:fixed}.attendance-table-quincenal td:first-child,.attendance-table-quincenal th:first-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:250px}.attendance-table-quincenal td:nth-child(2),.attendance-table-quincenal th:nth-child(2){text-align:center;width:150px}.attendance-table-quincenal td,.attendance-table-quincenal th{overflow:hidden;padding:12px 8px;text-align:center}.attendance-table-quincenal thead{background:linear-gradient(135deg,#1e293b,#334155);color:#fff;z-index:100}.table-container-quincenal.expanded .attendance-table-quincenal thead{top:0;z-index:10}.attendance-table-quincenal th{border-bottom:2px solid #0f172a;font-weight:600;padding:12px 8px;text-align:center;white-space:nowrap}.attendance-table-quincenal th.sticky-col{background:linear-gradient(135deg,#1e293b,#334155);left:0;position:-webkit-sticky;position:sticky;z-index:101}.attendance-table-quincenal th.employee-col{left:0;min-width:200px;padding-left:20px;text-align:left}.attendance-table-quincenal th.status-col{left:200px;min-width:100px}.mes-header{background:#3b82f61a;border-left:1px solid #ffffff1a;border-right:1px solid #ffffff1a}.quincena-header{background:#3b82f60d;font-size:11px;padding:8px 12px!important}.attendance-table-quincenal tbody{display:block;max-height:90vh;overflow-y:auto}.attendance-table-quincenal tbody tr{height:50px}.attendance-table-quincenal tbody tr,.attendance-table-quincenal thead{display:table;table-layout:fixed;width:100%}.attendance-table-quincenal tbody tr{border-bottom:1px solid #e2e8f0}.attendance-table-quincenal tbody tr:hover{background-color:#f8fafc}.attendance-table-quincenal td{padding:12px 8px;text-align:center;vertical-align:middle}.attendance-table-quincenal td.employee-name,.attendance-table-quincenal td.employee-status{background:#fff;position:-webkit-sticky;position:sticky;z-index:10}.attendance-table-quincenal tbody tr:hover td.employee-name,.attendance-table-quincenal tbody tr:hover td.employee-status{background-color:#f8fafc}.employee-name{font-weight:500;max-width:200px;min-width:200px;overflow:hidden;padding-left:20px!important;text-align:left;text-overflow:ellipsis}.employee-status{left:200px}.badge{font-size:11px}.badge-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.badge-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.quincena-cell{font-size:16px;padding:8px!important;transition:all .2s;-webkit-user-select:none;user-select:none}.quincena-cell:hover{background-color:#f1f5f9!important;transform:scale(1.1)}.quincena-cell.empty{color:#cbd5e1}.quincena-cell.asistio{color:#10b981}.quincena-cell.falta{color:#ef4444}.no-data{color:#94a3b8;font-style:italic;padding:40px 20px!important}.modal-overlay{padding:20px;z-index:10002}.modal-header{padding:24px}.modal-header h3{align-items:center;color:#1e293b;display:flex;font-size:20px;font-weight:700;gap:12px;margin:0}.modal-close{color:#94a3b8;font-size:28px}.modal-close:hover{color:#64748b}.modal-footer{padding:20px 24px}.instructions-content h4{color:#1e293b;font-size:16px;font-weight:700;margin:24px 0 12px}.instructions-content ul{color:#475569;line-height:1.8;margin:0;padding-left:20px}.instructions-content li{margin-bottom:8px}.instructions-content strong{color:#1e293b;font-weight:600}.modal-form{display:flex;flex-direction:column;gap:20px}.form-group{gap:8px}.form-text{margin-top:4px}.filter-summary{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:16px}.filter-summary p{color:#475569;font-size:14px}@media (max-width:768px){.attendance-quincenal-container{padding:16px}.attendance-quincenal-header{flex-direction:column;gap:16px}.header-actions{flex-wrap:wrap;width:100%}.header-actions button,.header-actions select{flex:1 1;min-width:120px}.attendance-legend{align-items:flex-start;flex-direction:column;gap:12px}.legend-note{margin-left:0}.modal-content{margin:20px;max-width:100%}}.load-more-container{background:#fff;border-top:1px solid #e2e8f0;display:flex;justify-content:center;padding:32px 24px}.btn-load-more{align-items:center;background:#fff;border:2px solid #3b82f6;border-radius:10px;box-shadow:0 2px 8px #3b82f626;color:#3b82f6;cursor:pointer;display:flex;font-family:inherit;font-size:14px;font-weight:600;gap:8px;padding:12px 32px;transition:all .3s}.btn-load-more:hover:not(:disabled){background:#3b82f6;box-shadow:0 4px 16px #3b82f64d;color:#fff;transform:translateY(-2px)}.btn-load-more:disabled{cursor:not-allowed;opacity:.6;transform:none}.emails-container{margin:0 auto;max-width:1200px;padding:24px}.emails-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:24px}.emails-header h1{color:#1e293b;display:flex;font-size:28px;font-weight:700;gap:12px;margin:0 0 8px}.emails-header h1,.header-actions{align-items:center}.auth-status{border-radius:8px;display:inline-flex;font-size:14px;padding:10px 20px}.auth-status.success{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border:2px solid #10b981;color:#065f46}.auth-status.error{background:linear-gradient(135deg,#fee2e2,#fecaca);border:2px solid #ef4444;color:#991b1b}.btn{border:none;border-radius:8px;font-size:14px;font-weight:600;gap:8px;padding:10px 20px}.btn-primary:hover:not(:disabled){box-shadow:0 4px 12px #3b82f666}.btn-primary:disabled{opacity:.5}.btn-outline{border:2px solid #e2e8f0}.btn-outline:hover{background:#eff6ff;border-color:#3b82f6}.btn-outline-danger{background:#fff;border:2px solid #fee2e2;color:#ef4444}.btn-outline-danger:hover{background:#fef2f2;border-color:#ef4444}.btn-lg{font-size:16px;justify-content:center;padding:14px 28px;width:100%}.email-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden}.card-header{background:linear-gradient(135deg,#f8fafc,#f1f5f9);padding:20px 24px}.card-header h3{color:#1e293b;font-size:18px;font-weight:700;gap:10px}.card-body{padding:24px}.card-body.text-center{text-align:center}.auth-setup{margin:0 auto;max-width:500px;padding:40px 20px}.auth-setup svg{margin-bottom:20px}.auth-setup h3{color:#1e293b;font-size:24px;font-weight:700;margin:20px 0 12px}.auth-setup p{color:#64748b;font-size:15px;line-height:1.6;margin-bottom:24px}.auth-actions{align-items:center;display:flex;flex-direction:column;gap:16px}.auth-help{color:#94a3b8;font-size:13px;margin:0}.user-info-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:24px;padding:20px 24px}.user-info{color:#475569;font-size:14px}.user-info svg{color:#3b82f6;font-size:20px}.user-info span{color:#1e293b}.user-info small{color:#94a3b8;font-size:12px;margin-left:auto}.form-group label{color:#334155;font-weight:600}.form-control{border:2px solid #e2e8f0;resize:vertical}.form-control::placeholder{color:#cbd5e1}.message-textarea{line-height:1.6;min-height:150px}.form-text{color:#94a3b8;display:block;font-size:12px;margin-top:6px}.email-lists{margin-bottom:20px}.email-lists label{color:#334155;display:block;font-size:14px;font-weight:600;margin-bottom:12px}.list-buttons{margin-bottom:8px}.advanced-settings{border:2px solid #e2e8f0;margin:24px 0;overflow:hidden}.advanced-settings details{cursor:pointer}.advanced-settings summary{align-items:center;background:#f8fafc;color:#475569;display:flex;font-size:14px;gap:8px;list-style:none;padding:14px 18px;-webkit-user-select:none;user-select:none}.advanced-settings summary::-webkit-details-marker{display:none}.advanced-settings summary:before{content:"▶";font-size:10px;transition:transform .2s}.advanced-settings details[open] summary:before{transform:rotate(90deg)}.advanced-settings summary:hover{background:#f1f5f9}.advanced-settings details[open] .form-group{border-top:1px solid #e2e8f0;margin:0;padding:18px}.send-actions{margin:24px 0}.strategy-info{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:2px solid #bfdbfe;margin-top:24px;padding:24px}.strategy-info h4{color:#1e40af;font-size:16px;font-weight:700;margin:0 0 16px}.strategy-info ul{padding-left:0}.strategy-info li{color:#1e40af;font-size:14px;line-height:1.6;margin-bottom:12px;padding-left:32px;position:relative}.strategy-info li:before{font-size:18px;left:0;position:absolute}.strategy-info strong{color:#1e3a8a;font-weight:600}.loading{color:#64748b;font-size:16px}@media (max-width:768px){.emails-container{padding:16px}.emails-header{flex-direction:column;gap:16px}.header-actions{flex-direction:column;width:100%}.auth-status,.header-actions button{justify-content:center;width:100%}.user-info{flex-wrap:wrap}.user-info small{margin-left:0;width:100%}.list-buttons{flex-direction:column}.list-buttons button{width:100%}.card-body,.strategy-info{padding:16px}.strategy-info li{font-size:13px;padding-left:28px}}.form-control::-webkit-scrollbar{width:8px}.form-control::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.form-control::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.form-control::-webkit-scrollbar-thumb:hover{background:#94a3b8}.template-manager-modal{max-height:90vh;max-width:800px;overflow-y:auto;width:90%}.template-manager-modal .modal-body{padding:24px}.templates-list{border-top:2px solid #e2e8f0;margin-top:32px;padding-top:24px}.templates-list h4{color:#1e293b;font-size:18px;font-weight:600;margin-bottom:16px}.templates-list .data-table{margin-top:16px}.templates-list .data-table td{vertical-align:middle}.templates-list .btn-sm{font-size:13px;padding:6px 12px}.modal-actions{padding-top:20px}.email-history-container{margin:0 auto;max-width:1400px;padding:24px}.page-header{margin-bottom:32px}.page-header h1{font-size:28px;font-weight:700;gap:12px;margin:0 0 8px}.stats-grid{margin-bottom:32px}.stat-card{padding:24px}.stat-icon{font-size:24px;height:56px;width:56px}.stat-content h3{font-size:32px;margin:0 0 4px}.stat-content p{color:#64748b;font-size:14px;margin:0}.filters-section{align-items:flex-end;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;gap:16px;margin-bottom:24px;padding:24px}.filter-group{flex:1 1;min-width:200px}.filter-group label{display:block;font-size:14px;margin-bottom:8px}.history-table-container{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.date-cell{align-items:center;color:#64748b;display:flex;gap:8px}.date-cell svg{color:#94a3b8}.text-success{color:#10b981;font-weight:600}.text-danger{color:#ef4444;font-weight:600}.badge-success{background:#d1fae5;color:#065f46}.badge-danger{background:#fee2e2;color:#991b1b}.badge-secondary{background:#f1f5f9;color:#64748b}.badge-info{background:#dbeafe;color:#1e40af}.empty-state,.loading-state{color:#94a3b8;padding:60px 20px;text-align:center}.empty-state h3{color:#64748b;font-size:20px;margin:16px 0 8px}.email-detail-modal{max-height:90vh;max-width:800px;overflow-y:auto;width:90%}.recipients-table-wrapper{margin-top:12px;overflow-x:auto}.recipients-table-wrapper .data-table td,.recipients-table-wrapper .data-table th{white-space:nowrap}.modal-body{max-height:60vh;padding:24px}.detail-section{margin-bottom:32px}.detail-section:last-child{margin-bottom:0}.detail-section h4{border-bottom:2px solid #e2e8f0;color:#1e293b;font-size:18px;font-weight:600;margin-bottom:16px;padding-bottom:8px}.detail-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.detail-item{display:flex;flex-direction:column;gap:4px}.detail-item label{color:#64748b;font-size:13px;font-weight:600}.detail-item span{color:#1e293b;font-size:15px}.message-preview{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;color:#475569;font-size:14px;max-height:300px;overflow-y:auto;padding:16px;white-space:pre-wrap;word-break:break-word}.failed-list{display:flex;flex-direction:column;gap:8px}.failed-item{align-items:center;background:#fef2f2;border:1px solid #fee2e2;border-radius:8px;display:flex;gap:12px;justify-content:space-between;padding:12px}.failed-email{color:#991b1b;font-weight:600}.failed-reason{color:#dc2626;flex:1 1;font-size:13px;text-align:right}@media (max-width:768px){.filters-section{flex-direction:column}.filter-group{width:100%}.detail-grid{grid-template-columns:1fr}.failed-item{align-items:flex-start;flex-direction:column}.failed-reason{text-align:left}}.ficha-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 4px 6px #0000001a;transition:all .3s ease}.ficha-card:hover{box-shadow:0 8px 15px #00000026;transform:translateY(-2px)}.ficha-card-header{background:linear-gradient(135deg,#1e40af,#3b82f6);color:#fff;padding:16px 20px 12px;position:relative}.ficha-card-title{font-size:16px;font-weight:600;line-height:1.3;margin:0 0 8px}.ficha-status{border-radius:20px;font-size:12px;font-weight:500;padding:4px 12px;position:absolute;right:16px;text-transform:uppercase;top:12px}.ficha-status.pendiente{background:#fff3cd;color:#856404}.ficha-status.aprobada{background:#d4edda;color:#155724}.ficha-status.rechazada{background:#f8d7da;color:#721c24}.ficha-card-body{padding:16px 20px}.ficha-meta{color:#666;display:flex;font-size:13px;justify-content:space-between;margin-bottom:12px}.ficha-description{margin-bottom:16px}.ficha-description p{color:#333;font-size:14px;margin:0 0 6px}.ficha-actions{border-top:1px solid #f0f0f0;gap:8px;justify-content:space-between;margin-top:12px;padding-top:12px}.btn-ficha{border:none;border-radius:4px;cursor:pointer;flex:1 1;font-size:13px;font-weight:500;padding:10px 12px;text-align:center;transition:all .2s ease;white-space:nowrap}.btn-ficha.primary{background:#007bff;color:#fff}.btn-ficha.success{background:#28a745;color:#fff}.btn-ficha.danger{background:#dc3545;color:#fff}.btn-ficha.secondary{background:#6c757d;color:#fff}.btn-ficha:hover{box-shadow:0 2px 4px #0003;transform:translateY(-1px)}.fichas-empty{color:#666;padding:60px 20px;text-align:center}.fichas-empty .icon{font-size:48px;margin-bottom:16px;opacity:.5}.stats-bar{gap:24px;margin-bottom:24px;padding:16px 20px}.stat-item{font-size:14px}.stat-item.rechazadas{color:#721c24}:root{--umsnh-blue-primary:#1e40af;--umsnh-blue-secondary:#3b82f6;--umsnh-navy-primary:#0d47a1;--umsnh-navy-secondary:#1565c0;--umsnh-red-primary:#b71c1c;--umsnh-red-secondary:#c62828}.filters{background:#f8f9fa;border-radius:5px;margin-bottom:20px;padding:20px}.view-toggles{display:flex;gap:5px}.inventory-card{height:100%}.inventory-card .card-header{align-items:center;display:flex;justify-content:space-between}.inventory-card .card-body p{color:#666;font-size:14px;margin-bottom:8px}.inventory-card .card-footer{border-top:1px solid #e0e0e0;margin-top:15px;padding-top:15px}.btn-sm{font-size:12px;margin-right:5px;padding:6px 12px}.btn.btn-sm.btn-secondary.btn-icon{background:#fff!important;border:1px solid #e2e8f0!important;color:#64748b!important;margin-right:0!important;min-height:32px!important;min-width:32px!important;padding:6px!important}.btn.btn-sm.btn-secondary.btn-icon:hover{background:#f8fafc!important;border-color:#cbd5e1!important;color:#1e293b!important}.btn.btn-sm.btn-danger.btn-icon{background:#fef2f2!important;border:1px solid #fecaca!important;color:#991b1b!important;margin-right:0!important;min-height:32px!important;min-width:32px!important;padding:6px!important}.btn.btn-sm.btn-danger.btn-icon:hover{background:#fee2e2!important;border-color:#fca5a5!important;color:#7f1d1d!important}.building-selector{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}.building-details h3{margin-bottom:10px}.progress-bar{background-color:#e0e0e0;border-radius:5px;height:10px;margin-top:10px;width:100%}.flex-1{flex:1 1}.page-container{margin:0 auto;max-width:1400px;padding:2rem}.page-header{border-bottom:2px solid #e0e0e0;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem}.page-header,.page-header h1{align-items:center;display:flex}.page-header h1{color:#333;font-size:1.8rem;gap:.5rem}.page-header h1 svg{color:#2196f3}.page-header p{color:#666;font-size:.9rem;margin-top:.5rem}.stat-card{box-shadow:0 2px 8px #0000001a}.stat-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-4px)}.stat-content h3{color:#333;font-size:2rem;margin:0}.stat-content p{color:#666;margin:.25rem 0 0}.stat-content small{color:#999;font-size:.8rem}.card{box-shadow:0 2px 8px #0000001a;margin-bottom:1.5rem;overflow:hidden}.card-header{background:#fafafa;border-bottom:1px solid #e0e0e0;justify-content:space-between;padding:1.25rem 1.5rem}.card-header,.card-header h3{align-items:center;display:flex}.card-header h3{color:#333;font-size:1.2rem;gap:.5rem;margin:0}.card-header small{color:#666;display:block;font-weight:400;margin-left:1rem;margin-top:.25rem}.card-body{padding:1.5rem}.filters-section{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.search-box{flex:1 1;min-width:250px;position:relative}.search-box svg{color:#999;left:12px;position:absolute;top:50%;transform:translateY(-50%)}.search-box input{border:1px solid #ddd;border-radius:8px;font-size:.9rem;padding:.75rem 1rem .75rem 2.5rem;transition:border-color .2s;width:100%}.search-box input:focus{border-color:#2196f3;box-shadow:0 0 0 3px #2196f31a;outline:none}.filter-select{background:#fff;border:1px solid #ddd;border-radius:8px;cursor:pointer;font-size:.9rem;min-width:200px;padding:.75rem 1rem}.filter-select:focus{border-color:#2196f3;outline:none}.data-table{background:#fff}.data-table thead{background:linear-gradient(135deg,#0d47a1,#1565c0);background:linear-gradient(135deg,var(--umsnh-navy-primary) 0,var(--umsnh-navy-secondary) 100%)}.data-table thead th{color:#fff;font-size:.9rem;font-weight:600;letter-spacing:.5px;padding:1rem;text-align:left;text-transform:uppercase}.data-table tbody tr{border-bottom:1px solid #e0e0e0;transition:background-color .2s}.data-table tbody tr:hover{background-color:#f8f9fa}.data-table tbody tr:last-child{border-bottom:none}.data-table tbody td{color:#333;font-size:.9rem;padding:1rem}.data-table tbody td strong{color:#2c3e50;font-weight:600}.btn{font-size:.9rem;gap:.5rem;padding:.65rem 1.25rem;text-decoration:none;transition:all .2s ease}.action-buttons .btn.btn-secondary,.btn.btn-secondary.btn-icon,.btn.btn-secondary.btn-sm,.btn.btn-secondary.btn-sm.btn-icon,table .btn.btn-secondary{background:#fff!important;border:1px solid #e2e8f0!important;color:#64748b!important}.action-buttons .btn.btn-secondary:hover,.btn.btn-secondary.btn-icon:hover,.btn.btn-secondary.btn-sm.btn-icon:hover,.btn.btn-secondary.btn-sm:hover,table .btn.btn-secondary:hover{background:#f8fafc!important;border-color:#cbd5e1!important;color:#1e293b!important}.action-buttons .btn.btn-danger,.btn.btn-danger.btn-icon,.btn.btn-danger.btn-sm,.btn.btn-danger.btn-sm.btn-icon,table .btn.btn-danger{background:#fef2f2!important;border:1px solid #fecaca!important;color:#991b1b!important}.action-buttons .btn.btn-danger:hover,.btn.btn-danger.btn-icon:hover,.btn.btn-danger.btn-sm.btn-icon:hover,.btn.btn-danger.btn-sm:hover,table .btn.btn-danger:hover{background:#fee2e2!important;border-color:#fca5a5!important;color:#7f1d1d!important}.btn-primary{background:#6366f1!important;border:1px solid #6366f1!important;border-radius:6px;color:#fff!important;font-weight:500;padding:10px 20px;transition:all .2s ease}.btn-primary:hover:not(:disabled){background:#4f46e5!important;border-color:#4f46e5!important;box-shadow:0 2px 4px #6366f14d}.btn-success{background:#34d399!important;border:1px solid #34d399!important;border-radius:6px;color:#fff!important;font-weight:500;padding:10px 20px;transition:all .2s ease}.btn-success:hover:not(:disabled){background:#10b981!important;border-color:#10b981!important;box-shadow:0 2px 4px #34d3994d}.btn-secondary{border:1px solid #e2e8f0;border-radius:6px;padding:10px 20px}.btn-outline-primary,.btn-secondary{font-weight:500;transition:all .2s ease}.btn-outline-primary{background:#0000;border:2px solid #6366f1;border-radius:6px;color:#6366f1;padding:8px 18px}.btn-outline-primary:hover:not(:disabled){background:#6366f1;box-shadow:0 2px 4px #6366f133;color:#fff;transform:translateY(-1px)}.btn-secondary:hover{border-color:#cbd5e1;color:#1e293b}.btn-sm{font-size:.85rem;padding:.4rem .8rem}.badge{display:inline-block;padding:.35rem .75rem}.badge-primary{background-color:#cce5ff;color:#004085}.badge-info{background-color:#d1ecf1;color:#0c5460}.badge-warning{border:1px solid #fde68a!important}.action-buttons{gap:.5rem}.btn-icon{border-radius:6px;display:inline-flex;padding:.5rem;transition:all .2s}.btn-edit{background:#f8fafc!important;border:1px solid #e2e8f0!important;color:#475569!important}.btn-edit:hover{background:#f1f5f9!important;border-color:#cbd5e1!important;box-shadow:0 1px 3px #0000001a;color:#1e293b!important;transform:translateY(-1px)}.btn-delete{background:#fef2f2!important;border:1px solid #fecaca!important;color:#991b1b!important}.btn-delete:hover{background:#fee2e2!important;border-color:#fca5a5!important;box-shadow:0 1px 3px #0000001a;color:#7f1d1d!important;transform:translateY(-1px)}.form-group{margin-bottom:1.25rem}.form-group label{align-items:center;color:#333;display:flex;gap:.5rem}.form-control{border:1px solid #ddd;font-size:.9rem;padding:.75rem;transition:border-color .2s}.form-control:focus{border-color:#2196f3;box-shadow:0 0 0 3px #2196f31a}.form-control:disabled{background-color:#f5f5f5}.form-row{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172abf;padding:1rem;z-index:9999}.modal-content{animation:slideUp .3s ease-out;border-radius:16px;box-shadow:0 25px 50px -12px #00000040;display:flex;flex-direction:column;max-width:600px;overflow:hidden}.modal-content.large{max-width:800px}.modal-content.extra-large{max-width:1200px}.modal-header{background:linear-gradient(135deg,#f8fafc,#fff);padding:24px 28px}.modal-header h2,.modal-header h3{align-items:center;color:#1e293b;display:flex;font-size:20px;font-weight:600;gap:10px;margin:0}.modal-header h2 svg,.modal-header h3 svg{color:#3b82f6;font-size:24px}.modal-close{background:#f1f5f9;border-radius:10px;font-size:24px;font-weight:300;height:40px;line-height:1;transition:all .2s ease;width:40px}.modal-close:hover{background:#fee2e2;color:#dc2626;transform:scale(1.1)}.modal-body{flex:1 1;overflow-y:auto;padding:28px}.modal-body::-webkit-scrollbar{width:8px}.modal-body::-webkit-scrollbar-track{background:#f1f5f9;border-radius:10px}.modal-body::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:10px}.modal-body::-webkit-scrollbar-thumb:hover{background:#94a3b8}.modal-footer{background:#f8fafc;padding:20px 28px}.modal-form{padding:0}.form-group label .required{color:#dc2626;margin-left:4px}.form-control{border:1px solid #cbd5e1;box-sizing:border-box;padding:12px 16px;transition:all .2s ease}.form-control:focus{background:#fff}.form-control:disabled{background:#f1f5f9}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' width='12' height='12'%3E%3Cpath fill='%2364748b' d='M6 9 1 4h10z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:40px}textarea.form-control{font-family:inherit}.modal-actions{border-top:1px solid #e2e8f0;gap:12px;margin-top:24px}.user-info-modal{background:#f8fafc;border:1px solid #e2e8f0}.user-info-modal p{color:#475569;font-size:14px;margin:8px 0}.user-info-modal strong{color:#1e293b;font-weight:600}@media (max-width:768px){.modal-content{max-height:85vh;max-width:95%}.modal-body,.modal-header{padding:20px}.modal-footer{padding:16px 20px}.modal-header h2,.modal-header h3{font-size:18px}}.loading{color:#666;font-size:1.2rem;min-height:400px}@media (max-width:768px){.page-container{padding:1rem}.page-header{align-items:flex-start;flex-direction:column;gap:1rem}.stats-grid{grid-template-columns:1fr}.filters-section{flex-direction:column}.filter-select,.search-box{width:100%}.form-row{grid-template-columns:1fr}.data-table{font-size:.8rem}.data-table tbody td,.data-table thead th{padding:.75rem .5rem}}.attendance-legend{align-items:center;background:linear-gradient(135deg,#eceff1,#cfd8dc);border:2px solid #b0bec5;border-radius:10px;box-shadow:0 2px 8px #37474f1a;display:flex;flex-wrap:wrap;gap:2rem;margin-bottom:1.5rem;padding:1.25rem 1.5rem}.legend-item{background:#fff;border-radius:6px;box-shadow:0 1px 3px #0000001a;color:#37474f;font-weight:600;gap:.6rem;padding:.5rem .75rem}.icon-asistio{color:#3b82f6;filter:drop-shadow(0 1px 2px rgba(46,125,50,.3));font-size:1.3rem}.icon-falta{color:#c62828;filter:drop-shadow(0 1px 2px rgba(198,40,40,.3));font-size:1.3rem}.icon-empty{color:#90a4ae;font-size:.9rem}.legend-note{color:#546e7a;font-size:.9rem;font-style:italic;font-weight:500;margin-left:auto}.table-container-quincenal{border:2px solid #b0bec5;border-radius:10px;box-shadow:0 4px 12px #37474f26;max-height:85vh;overflow-x:auto;position:relative}.table-container-quincenal.expanded{background:#fff;border:1px solid #e5e7eb;border-radius:8px;bottom:10px;box-shadow:0 8px 32px #0000001a;left:10px;margin:0;max-height:calc(100vh - 150px);padding:0;position:fixed;right:10px;top:140px}.attendance-table-quincenal{background:#fff;border-collapse:initial;border-spacing:0;min-width:1800px;width:100%}.table-container-quincenal.expanded .attendance-table-quincenal{font-size:.85rem;min-width:calc(100vw - 40px)}.attendance-table-quincenal thead{background:#fff;position:-webkit-sticky;position:sticky;top:0;z-index:10}.attendance-table-quincenal thead tr:first-child{background:linear-gradient(135deg,#0d47a1,#1565c0);box-shadow:0 2px 8px #0d47a14d}.attendance-table-quincenal thead tr:last-child{background:linear-gradient(135deg,#1565c0,#1976d2)}.mes-header{border-bottom:2px solid #fff3;border-right:2px solid #ffffff4d;font-size:.9rem;font-weight:700;letter-spacing:1.2px;padding:.85rem;text-transform:uppercase}.mes-header,.quincena-header{color:#fff;text-align:center;text-shadow:0 1px 2px #0003}.quincena-header{border-right:1px solid #fff3;font-size:.8rem;font-weight:600;padding:.6rem}.employee-col{border-right:3px solid #b0bec5!important;left:0;min-width:250px}.employee-col,.status-col{background:linear-gradient(135deg,#37474f,#546e7a)!important;color:#fff;font-weight:700;padding:.85rem;position:-webkit-sticky;position:sticky;text-shadow:0 1px 2px #0000004d;z-index:11}.status-col{border-right:4px solid #78909c!important;left:250px;min-width:100px;text-align:center}.employee-name{border-right:3px solid #b0bec5!important;color:#263238;left:0;min-width:250px;padding:1rem 1.25rem;white-space:nowrap}.employee-name,.employee-status{background:linear-gradient(135deg,#eceff1,#f5f5f5)!important;box-shadow:2px 0 4px #0000000d;position:-webkit-sticky;position:sticky;z-index:8}.employee-status{border-right:4px solid #78909c!important;left:250px;min-width:100px;padding:1rem;text-align:center}.quincena-cell{border:1px solid #cfd8dc;cursor:pointer;font-size:1.3rem;min-width:50px;padding:.8rem;text-align:center;transition:all .2s ease}.quincena-cell:hover{background:#eceff1;box-shadow:0 2px 8px #37474f33;transform:scale(1.15);z-index:5}.quincena-cell.asistio{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border-color:#81c784;color:#1e40af;font-weight:700}.quincena-cell.asistio:hover{background:linear-gradient(135deg,#c8e6c9,#a5d6a7);border-color:#4caf50}.quincena-cell.falta{background:linear-gradient(135deg,#ffebee,#ffcdd2);border-color:#e57373;color:#b71c1c;font-weight:700}.quincena-cell.falta:hover{background:linear-gradient(135deg,#ffcdd2,#ef9a9a);border-color:#ef5350}.quincena-cell.empty{background:#fafafa;border-color:#eceff1;color:#90a4ae}.quincena-cell.empty:hover{background:#f5f5f5;border-color:#cfd8dc;color:#78909c}.attendance-table-quincenal tbody tr{border-bottom:1px solid #cfd8dc;transition:background-color .2s}.attendance-table-quincenal tbody tr:hover{background-color:#fafafa}.attendance-table-quincenal tbody tr:hover .employee-name,.attendance-table-quincenal tbody tr:hover .employee-status{background:linear-gradient(135deg,#e3f2fd,#bbdefb)!important}.no-data{color:#78909c;font-size:1.1rem;font-weight:500;padding:3rem;text-align:center}.attendance-instructions{background:linear-gradient(135deg,#fafafa,#eceff1);border-left:5px solid #1565c0;border-radius:10px;box-shadow:0 2px 8px #37474f1a;margin-top:2rem;padding:1.5rem 2rem}.attendance-instructions h3{align-items:center;color:#0d47a1;display:flex;font-weight:700;gap:.5rem;margin-top:0}.attendance-instructions ul{margin:1rem 0 0;padding-left:1.5rem}.attendance-instructions li{color:#546e7a;font-weight:500;line-height:1.7;margin-bottom:.6rem}.attendance-instructions strong{color:#263238;font-weight:700}.badge-success{background:#d1fae5!important;border:1px solid #a7f3d0!important;border-radius:20px}.badge-danger,.badge-success{box-shadow:0 1px 2px #0000000d;font-size:.8rem;font-weight:600;letter-spacing:.5px;padding:.4rem .9rem;text-transform:uppercase}.badge-danger{background:#fee2e2!important;border:1px solid #fecaca!important;border-radius:20px}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.quincena-cell:active{animation:pulse .3s ease}.table-container-quincenal::-webkit-scrollbar{height:12px}.table-container-quincenal::-webkit-scrollbar-track{background:#eceff1;border-radius:10px}.table-container-quincenal::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#78909c,#546e7a);border:2px solid #eceff1;border-radius:10px}.table-container-quincenal::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#546e7a,#37474f)}.table-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0000004d;bottom:0;left:0;position:fixed;right:0;top:0;z-index:999}.table-container-quincenal.expanded{z-index:1000}body.modal-open .page-header{background:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 2px 8px #0000001a;height:76px;left:0;margin-bottom:0;padding:1rem 2rem;position:fixed;right:0;top:64px;z-index:1001}body.modal-open .attendance-instructions,body.modal-open .attendance-legend{display:none}body.modal-open .card{background:#0000;border-radius:0;box-shadow:none;margin:0}body.modal-open .card-body{padding:0}body.modal-open .action-buttons{gap:12px}body.modal-open .action-buttons .btn{font-size:.9rem;padding:8px 16px}.instructions-content h4{color:#0d47a1;color:var(--umsnh-navy-primary);font-size:1.1rem;margin-bottom:.5rem;margin-top:1.5rem}.instructions-content h4:first-child{margin-top:0}.instructions-content ul{margin-bottom:1rem}.instructions-content li{align-items:center;display:flex;gap:8px;margin-bottom:.5rem}.instructions-content .icon-asistio{color:#4caf50}.instructions-content .icon-falta{color:#f44336}.instructions-content .icon-sin-registrar{color:#9e9e9e}.filter-summary{background:#f8f9fa;border-left:4px solid #0d47a1;border-left:4px solid var(--umsnh-navy-primary);border-radius:6px;margin-top:1rem;padding:12px}.filter-summary p{color:#555;font-size:.95rem;margin:0}.auth-setup{padding:2rem;text-align:center}.auth-setup h3{color:#0d47a1;color:var(--umsnh-navy-primary);margin:1rem 0}.auth-actions{margin-top:2rem}.auth-help{color:#666;font-size:.9rem;margin-top:1rem}.auth-status{align-items:center;border-radius:6px;display:flex;font-size:.9rem;font-weight:600;gap:8px;padding:8px 16px}.auth-status.success{background:#e8f5e8;border:1px solid #4caf50;color:#3b82f6}.auth-status.error{background:#ffeaea;border:1px solid #f44336;color:#c62828}.user-info-card{margin-bottom:2rem}.user-info{background:#f8f9fa;border-left:4px solid #0d47a1;border-left:4px solid var(--umsnh-navy-primary);border-radius:8px;padding:1rem}.user-info span{color:#0d47a1;color:var(--umsnh-navy-primary);font-weight:600}.user-info small{color:#666;font-size:.85rem}.email-lists{margin:1rem 0}.list-buttons{display:flex;flex-wrap:wrap;gap:8px;margin-top:.5rem}.advanced-settings{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;margin:2rem 0;padding:1rem}.advanced-settings summary{color:#0d47a1;color:var(--umsnh-navy-primary);cursor:pointer;font-weight:600;margin-bottom:1rem}.send-actions{margin-top:2rem;text-align:center}.strategy-info{background:linear-gradient(135deg,#e3f2fd,#f3e5f5);border-left:4px solid #0d47a1;border-left:4px solid var(--umsnh-navy-primary);border-radius:12px;margin-top:2rem;padding:1.5rem}.strategy-info h4{color:#0d47a1;color:var(--umsnh-navy-primary);font-size:1.1rem;margin-bottom:1rem}.strategy-info ul{list-style:none;margin:0;padding:0}.strategy-info li{background:#ffffffb3;border-radius:6px;font-size:.95rem;margin-bottom:.75rem;padding:.5rem}.user-info{align-items:center;gap:12px}.user-avatar{background:linear-gradient(135deg,#0d47a1,#1565c0);background:linear-gradient(135deg,var(--umsnh-navy-primary),var(--umsnh-navy-secondary));box-shadow:0 2px 8px #0d47a14d;font-size:1.1rem;height:40px;width:40px}.user-details{display:flex;flex-direction:column;gap:2px}.user-name{color:var(--umsnh-text-primary)}.user-id{color:var(--umsnh-text-tertiary);font-size:.8rem}.badge{border-radius:20px;font-size:.8rem;letter-spacing:.5px;padding:6px 12px;text-transform:uppercase}.badge-admin{background:linear-gradient(135deg,#b71c1c,#c62828);background:linear-gradient(135deg,var(--umsnh-red-primary),var(--umsnh-red-secondary));color:#fff}.badge-coordinador{background:linear-gradient(135deg,#0d47a1,#1565c0);background:linear-gradient(135deg,var(--umsnh-navy-primary),var(--umsnh-navy-secondary));color:#fff}.badge-usuario{background:linear-gradient(135deg,var(--umsnh-gray-medium),var(--umsnh-gray-light));color:#fff}.status{border-radius:20px;font-size:.8rem;font-weight:600;padding:6px 12px}.status-active{background:linear-gradient(135deg,#e8f5e8,#c8e6c9);color:#1e40af}.status-inactive{background:linear-gradient(135deg,#ffebee,#ffcdd2);color:#b71c1c;color:var(--umsnh-red-primary)}.action-buttons{align-items:center;gap:8px}.btn-icon{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:1rem;height:36px;justify-content:center;transition:all .3s ease;width:36px}.btn-edit{background:linear-gradient(135deg,#e3f2fd,#bbdefb);color:#0d47a1;color:var(--umsnh-navy-primary)}.btn-edit:hover{background:linear-gradient(135deg,#0d47a1,#1565c0);background:linear-gradient(135deg,var(--umsnh-navy-primary),var(--umsnh-navy-secondary));color:#fff;transform:scale(1.1)}.btn-password{background:linear-gradient(135deg,#fff3e0,#ffe0b2);color:#e65100}.btn-password:hover{background:linear-gradient(135deg,#e65100,#ff9800);color:#fff;transform:scale(1.1)}.btn-activate{background:linear-gradient(135deg,#e8f5e8,#c8e6c9);color:#1e40af}.btn-activate:hover{background:linear-gradient(135deg,#1e40af,#3b82f6);color:#fff;transform:scale(1.1)}.btn-deactivate{background:linear-gradient(135deg,#fff3e0,#ffe0b2);color:#ff9800}.btn-deactivate:hover{background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff;transform:scale(1.1)}.btn-delete{background:linear-gradient(135deg,#ffebee,#ffcdd2);color:#b71c1c;color:var(--umsnh-red-primary)}.btn-delete:hover{background:linear-gradient(135deg,#b71c1c,#c62828);background:linear-gradient(135deg,var(--umsnh-red-primary),var(--umsnh-red-secondary));color:#fff;transform:scale(1.1)}.form-control::placeholder{color:#9ca3af}.modal-footer{border-top:1px solid var(--umsnh-bg-tertiary);gap:16px;margin-top:32px;padding-top:24px}.form-row{grid-gap:20px;gap:20px;grid-template-columns:1fr 1fr;margin-bottom:20px}.form-group input,.form-group select,.form-group textarea{border:2px solid #d1d5db;border-radius:8px;box-sizing:border-box;color:var(--umsnh-text-primary);font-size:1rem;padding:12px 16px;transition:all .3s ease;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#1e40af;box-shadow:0 0 0 3px #1b5e201a}.form-group input::placeholder,.form-group textarea::placeholder{color:#9ca3af}.form-group select{-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 12px center;background-repeat:no-repeat;background-size:16px;padding-right:40px}.form-group textarea{min-height:80px;resize:vertical}.user-info-modal{background:linear-gradient(135deg,#e3f2fd,#bbdefb);border-left:4px solid #0d47a1;border-left:4px solid var(--umsnh-navy-primary);border-radius:8px;margin-bottom:20px;padding:16px}.user-info-modal strong{color:#0d47a1;color:var(--umsnh-navy-primary);display:block;font-size:1.1rem;margin-bottom:4px}.user-info-modal span{color:var(--umsnh-text-secondary);font-size:.95rem}.modal-actions{border-top:1px solid var(--umsnh-bg-tertiary);gap:16px;margin-top:32px;padding-top:24px}.empty-state{color:var(--umsnh-text-tertiary);padding:60px 40px}.empty-icon{font-size:4rem;margin-bottom:16px;opacity:.6}.empty-state h3{color:var(--umsnh-text-secondary);margin-bottom:8px}.empty-state p{font-size:1rem;margin-bottom:24px}body.modal-open{overflow:hidden}.modal-overlay{height:100%!important;left:0!important;position:fixed!important;top:0!important;width:100%!important;z-index:9999!important}.modal-content{position:relative;z-index:10000}.modal-form{max-height:calc(90vh - 120px);overflow-y:auto}.ficha-tecnica-preview{background:#fff;border:2px solid #ddd;border-radius:8px;box-shadow:0 4px 8px #0000001a;font-family:Arial,sans-serif;margin:20px auto;max-width:800px;padding:30px}.ficha-header{align-items:flex-start;border-bottom:3px solid #1e40af;display:flex;justify-content:space-between;margin-bottom:30px;padding-bottom:20px}.universidad-logo{flex:1 1;text-align:center}.lema{color:#1e40af;font-size:14px;font-style:italic;font-weight:700;margin-bottom:10px}.facultad-info{flex:2 1;text-align:center}.facultad-nombre{color:#0d47a1;color:var(--umsnh-navy-primary);font-size:18px;font-weight:700;margin-bottom:5px}.ficha-titulo{color:#b71c1c;color:var(--umsnh-red-primary);font-size:24px;font-weight:700;letter-spacing:2px;margin-top:15px}.ficha-content{line-height:1.6}.folio-control{color:#666;font-size:12px;margin-bottom:20px;text-align:right}.form-row{border:1px solid #ddd;display:flex;margin-bottom:15px;min-height:35px}.form-field{align-items:stretch;display:flex;flex:1 1}.form-field.full-width{width:100%}.field-label{background:#f5f5f5;border-right:1px solid #ddd;color:#333;font-weight:700;min-width:200px}.field-label,.field-value{align-items:center;display:flex;padding:8px 12px}.field-value{background:#fff;flex:1 1;min-height:20px}.fichas-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));margin-top:20px}.ficha-card{border:1px solid #ddd;border-radius:8px;cursor:pointer;overflow:hidden;position:relative;transition:transform .2s,box-shadow .2s}.ficha-card:hover{box-shadow:0 8px 16px #00000026;transform:translateY(-5px)}.ficha-preview-mini{height:300px;overflow:hidden;position:relative;transform:scale(.4);transform-origin:top left;width:250%}.ficha-preview-mini .ficha-tecnica-preview{border:none;box-shadow:none;margin:0;max-width:none;padding:20px}.ficha-overlay{align-items:flex-end;background:linear-gradient(#0000,#000c);bottom:0;color:#fff;display:flex;justify-content:space-between;left:0;padding:20px;position:absolute;right:0}.ficha-info h3{font-size:16px;font-weight:700;margin:0 0 5px}.ficha-info p{font-size:12px;margin:0;opacity:.9}.ficha-actions{display:flex;flex-direction:column;gap:10px}.ficha-actions button{border:none;border-radius:4px;cursor:pointer;font-size:12px;padding:6px 12px;transition:background-color .2s}.ficha-actions .btn-primary{background:#1e40af;color:#fff}.ficha-actions .btn-primary:hover{background:#3b82f6}.ficha-actions .btn-delete{background:#b71c1c;background:var(--umsnh-red-primary);color:#fff}.ficha-actions .btn-delete:hover{background:#c62828;background:var(--umsnh-red-secondary)}.user-fichas{margin-top:30px}.user-fichas h2{border-bottom:2px solid #1e40af;color:#0d47a1;color:var(--umsnh-navy-primary);margin-bottom:20px;padding-bottom:10px}.status{border-radius:4px;font-size:12px;font-weight:700;padding:4px 8px;text-transform:uppercase}.status.pendiente{background:#fff3cd;color:#856404}.status.aprobado{background:#d4edda;color:#155724}.status.rechazado{background:#f8d7da;color:#721c24}@media (max-width:768px){.fichas-grid{grid-template-columns:1fr}.ficha-header{text-align:center}.ficha-header,.form-row{flex-direction:column}.field-label{border-bottom:1px solid #ddd;border-right:none;min-width:auto}.ficha-overlay{align-items:flex-start;flex-direction:column;gap:10px}.ficha-actions{flex-direction:row;width:100%}}.ficha-tecnica-umsnh{background:#fff;border:2px solid #000;box-shadow:0 4px 8px #0000001a;color:#000;font-family:Times New Roman,serif;font-size:12px;line-height:1.4;margin:20px auto;max-width:800px;padding:20px}.ficha-header-institucional{border-bottom:2px solid #000;margin-bottom:20px;padding-bottom:15px;text-align:center}.universidad-info{margin-bottom:10px}.lema-institucional{color:#1e40af;font-size:10px;font-style:italic;margin-bottom:5px}.universidad-nombre{font-size:14px;font-weight:700;letter-spacing:.5px;margin-bottom:10px}.facultad-seccion{border-top:1px solid #000;padding-top:10px}.facultad-titulo{font-size:12px;font-weight:700;margin-bottom:10px}.documento-tipo h2{font-size:18px;font-weight:700;letter-spacing:2px;margin:0;text-decoration:underline}.ficha-contenido-principal{padding:20px 0}.seccion-control{border-bottom:1px solid #ddd;justify-content:space-between;margin-bottom:25px;padding-bottom:10px}.campo-linea,.seccion-control{align-items:center;display:flex}.campo-linea{gap:10px}.linea-relleno{font-family:monospace;letter-spacing:2px}.campo-fecha,.etiqueta{font-size:11px}.etiqueta{font-weight:700}.seccion-evento{margin-bottom:30px}.fila-campo{align-items:flex-start;display:flex;margin-bottom:15px;min-height:30px}.fila-campo.campo-completo{flex-direction:column}.fila-campo-doble{display:flex;gap:20px;margin-bottom:15px}.campo-mitad{display:flex;flex:1 1;flex-direction:column}.etiqueta-campo{color:#333;font-size:11px;font-weight:700;margin-bottom:5px}.campo-valor-subrayado{word-wrap:break-word;border-bottom:1px solid #000;flex:1 1;font-size:12px;line-height:1.3;margin-left:10px;min-height:20px;padding:2px 5px}.campo-completo .campo-valor-subrayado{margin-left:0;margin-top:5px}.campo-valor-textarea{word-wrap:break-word;background:#0000;border:1px solid #000;font-size:11px;line-height:1.4;margin-top:5px;min-height:60px;padding:8px}.seccion-firmas{border-top:1px solid #000;margin-top:40px;padding-top:20px}.linea-firma{display:flex;gap:40px;justify-content:space-between}.firma-campo{flex:1 1;text-align:center}.linea-firma-texto{align-items:end;border-bottom:1px solid #000;display:flex;height:30px;justify-content:center;margin-bottom:5px}.firma-etiqueta{font-size:10px;font-weight:700}.stats-bar{background:#f8f9fa;border-radius:8px;display:flex;gap:20px;margin-top:15px;padding:15px}.stat-item{background:#fff;border:1px solid #ddd;border-radius:5px;font-weight:700;padding:5px 10px}.stat-item.pendientes{background:#fff3cd;border-color:#ffeaa7;color:#856404}.stat-item.aprobadas{background:#d4edda;border-color:#c3e6cb;color:#155724}.solicitudes-lista{margin-top:20px}.solicitud-card{background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px;overflow:hidden;transition:box-shadow .2s ease}.solicitud-card:hover{box-shadow:0 4px 8px #00000026}.solicitud-header{align-items:flex-start;background:#f8f9fa;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:15px 20px}.solicitud-info-principal{flex:1 1}.evento-nombre{color:#0d47a1;color:var(--umsnh-navy-primary);font-size:18px;font-weight:700;margin:0 0 10px}.solicitud-metadata{color:#666;display:flex;flex-wrap:wrap;font-size:14px;gap:15px}.solicitud-acciones{align-items:flex-end;display:flex;flex-direction:column;gap:10px}.estado-badge{border-radius:20px;font-size:12px;font-weight:700;padding:6px 12px;white-space:nowrap}.estado-badge.pendiente{background:#fff3cd;border:1px solid #ffeaa7;color:#856404}.estado-badge.aprobada{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.estado-badge.rechazada{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.btn-ver-completa{background:#0d47a1;background:var(--umsnh-navy-primary);border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:12px;padding:8px 16px;transition:background .2s ease}.btn-ver-completa:hover{background:#1565c0;background:var(--umsnh-navy-secondary)}.solicitud-resumen{padding:20px}.resumen-items{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:15px}.resumen-item{font-size:14px}.resumen-item strong{color:#333}.objetivos-resumen{background:#f8f9fa;border-left:4px solid #1e40af;border-radius:5px;padding:15px}.objetivos-resumen p{color:#666;font-style:italic;margin:5px 0 0}.solicitud-footer{align-items:center;background:#f8f9fa;border-top:1px solid #eee;display:flex;justify-content:space-between;padding:15px 20px}.fecha-envio{color:#666;font-size:13px}.acciones-admin{display:flex;gap:10px}.btn-aprobar{background:#1e40af;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:12px;padding:8px 16px;transition:background .2s ease}.btn-aprobar:hover{background:#3b82f6}.btn-rechazar{background:#b71c1c;background:var(--umsnh-red-primary);border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:12px;padding:8px 16px;transition:background .2s ease}.btn-rechazar:hover{background:#c62828;background:var(--umsnh-red-secondary)}.btn-eliminar{background:#6c757d;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:12px;padding:8px 16px;transition:background .2s ease}.btn-eliminar:hover{background:#545b62}.modal-content.extra-large{max-height:90vh;max-width:900px;overflow-y:auto;width:95%}.ficha-preview-container{border:1px solid #ddd;border-radius:5px}.modal-actions{background:#f8f9fa;border-top:1px solid #ddd;justify-content:space-between;padding:20px}.btn-print{background:#0d47a1;background:var(--umsnh-navy-primary)}.btn-close-modal,.btn-print{border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:14px;padding:10px 20px}.btn-close-modal{background:#6c757d}.empty-state{color:#666;padding:60px 20px}.empty-state p{font-size:16px;margin:0}@media print{.ficha-tecnica-umsnh{border:1px solid #000;box-shadow:none;font-size:11px;margin:0;max-width:none;padding:15px}.modal-actions,.modal-header,.modal-overlay{display:none!important}.ficha-preview-container{border:none;overflow:visible}}@media (max-width:768px){.solicitud-header{align-items:stretch;flex-direction:column}.solicitud-acciones{align-items:center;flex-direction:row;justify-content:space-between;margin-top:15px}.solicitud-metadata{flex-direction:column;gap:8px}.resumen-items{grid-template-columns:1fr}.solicitud-footer{align-items:stretch;flex-direction:column;gap:15px}.acciones-admin{justify-content:center}.fila-campo-doble{flex-direction:column;gap:15px}.linea-firma{flex-direction:column;gap:30px}.ficha-tecnica-umsnh{margin:10px;padding:15px}}.a4-size{background-color:#fff;border:1px solid #ccc;box-sizing:border-box;height:167mm;margin:20px auto;max-height:680px;max-width:520px;padding:12px;position:relative;width:130mm;z-index:0}.a4-size:before{background-position:50%;background-repeat:no-repeat;background-size:cover;bottom:0;content:"";left:0;opacity:.3;position:absolute;right:0;top:0;z-index:1}.facultad{margin-left:20px;padding:10px;position:relative;text-align:center;z-index:2}.facultad h1{color:#002061;font-family:Arial,sans-serif;font-size:12px;font-weight:700;letter-spacing:1px;line-height:.8;margin-bottom:6px;margin-left:auto;max-width:200px;text-align:right;text-shadow:1px 1px 2px #0000001a;transform:translateY(50px) translateX(-20px)}.facultad p{color:#333;font-size:16px}.humanista{padding:20px;position:relative;text-align:center;z-index:2}.humanista h1{align-items:center;color:#002061;font-family:Arial,sans-serif;font-size:10px;font-weight:700;letter-spacing:1px;line-height:.7;margin-bottom:8px;margin-top:45px;text-align:center;text-shadow:1px 1px 2px #0000001a;text-transform:uppercase}.fecha-envio-container{align-items:flex-start;display:flex;justify-content:flex-end;margin:15px 0 25px;position:relative;z-index:2}.fecha-envio-label{color:grey;flex-shrink:0;font-family:Arial,sans-serif;font-size:11px;margin-right:5px;text-align:right}.fecha-envio{border-collapse:collapse;font-family:Arial,sans-serif;width:50%}.fecha-envio td{background-color:#fff;border:.5px solid #888;color:#333;font-size:8px;padding:6px 4px}.form-table{margin:-10px 0 5px}.field-value-centered{color:grey}.field-label-4col,.field-value-empty,.hour-label-small{font-size:12px;padding:5px 8px 30px!important}.hour-label-small{font-family:Century Gothic,sans-serif;vertical-align:top;width:10%}.hour-value-large{font-size:12px;padding:5px 8px 30px!important;width:35%}.form-table{border-collapse:collapse;font-family:Arial,sans-serif;font-size:10px;margin:10px 0 5px;width:100%}.form-table td{border:.5px solid #888;line-height:1.2;padding:5px 8px 30px;text-align:left;vertical-align:top}.field-label{color:grey;font-family:Century Gothic,sans-serif;width:30%}.field-label,.field-value{font-size:12px;text-align:left;vertical-align:top}.field-value{color:#333;width:70%}.field-value-centered{color:#333;font-size:11px;text-align:left;vertical-align:middle;width:70%}.field-label-4col{color:grey;font-family:Century Gothic,sans-serif;width:25%}.field-label-4col,.field-value-empty{font-size:8px;padding:1px 3px 4px!important;text-align:left;vertical-align:top}.field-value-empty{color:#333}.hour-label-small{color:grey;font-size:9px;padding:8px 4px!important;text-align:center;vertical-align:middle;width:7%}.hour-value-large{color:#333;font-size:9px;text-align:left;vertical-align:top;width:38%}.center-text{color:#5a7db8;font-size:12px;font-weight:700;margin:10px 0 5px;text-align:center}@media print{.ficha-umsnh-container{border:none;box-shadow:none;margin:0;padding:15mm;page-break-inside:avoid;width:100%}.fecha-envio td,.form-table td{border:.5px solid #000}}@media (max-width:768px){.ficha-umsnh-container{height:auto;max-height:none;padding:10px;width:100%}.facultad h1{font-size:16px;text-align:center;transform:none}.fecha-envio-container{justify-content:center}.fecha-envio{width:70%}.form-table{font-size:9px}.field-label,.field-label-4col,.field-value,.field-value-empty,.hour-value-large{font-size:10px}}.preview-modal-overlay{align-items:center;background:#000c;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.preview-modal-content{background:#f5f5f5;border-radius:8px;display:flex;flex-direction:column;height:95vh;overflow:hidden;width:95vw}.preview-controls{background:#2c3e50;color:#fff;flex-wrap:wrap;gap:10px;justify-content:space-between;padding:10px 20px}.modal-actions{align-items:center;gap:10px}.modal-btn{border:none;border-radius:4px;cursor:pointer;font-weight:700;padding:8px 16px;transition:background .3s}.btn-primary.modal-btn{background:#27ae60;color:#fff}.btn-primary.modal-btn:hover{background:#2ecc71}.btn-secondary.modal-btn{background:#f39c12;color:#fff}.btn-secondary.modal-btn:hover{background:#e67e22}.zoom-controls{align-items:center;display:flex;gap:10px}.zoom-btn{background:#3498db;border:none;border-radius:4px;color:#fff;cursor:pointer;font-weight:700;padding:8px 12px;transition:background .3s}.zoom-btn:hover{background:#2980b9}.zoom-btn.reset{background:#e74c3c}.zoom-btn.reset:hover{background:#c0392b}.zoom-level{color:#fff;font-weight:700;min-width:50px;text-align:center}.close-preview-btn{background:#e74c3c;border:none;border-radius:4px;color:#fff;cursor:pointer;font-weight:700;padding:8px 16px;transition:background .3s}.close-preview-btn:hover{background:#c0392b}.preview-container{align-items:flex-start;background:#e8e8e8;display:flex;flex:1 1;justify-content:center;overflow:auto;padding:20px}.preview-content{transition:transform .3s ease;will-change:transform}@media (max-width:768px){.preview-modal-content{border-radius:0;height:100vh;width:100vw}.preview-controls{align-items:stretch;flex-direction:column;gap:10px;padding:8px 15px}.zoom-controls{gap:8px;justify-content:center}.modal-actions{flex-wrap:wrap;justify-content:center}.close-preview-btn,.modal-btn,.zoom-btn{font-size:14px;padding:6px 12px}.preview-container{padding:10px}}.footer-signature{margin-top:15px;padding-top:5px;text-align:center}.footer-line{border-top:.5px solid #333;margin:15px auto 5px;width:150px}.footer-text{color:#333;font-weight:400;text-align:center}.folio-control,.footer-text{font-family:Arial,sans-serif;font-size:10px}.folio-control{bottom:20px;color:red;font-weight:700;left:30%;position:absolute;transform:translateX(-50%)}.a4-size .form-table td{padding:1px 3px 6px!important}.ficha-modal .modal-header-fixed{align-items:center;background:#2563eb;border-radius:12px 12px 0 0;box-shadow:0 2px 8px #0000001a;color:#fff;display:flex;justify-content:space-between;margin:0;padding:20px 30px;position:-webkit-sticky;position:sticky;top:0;z-index:10}.ficha-modal .modal-header-fixed h2{font-size:22px;font-weight:600;margin:0}.ficha-modal .btn-close{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:20px;height:36px;justify-content:center;transition:background-color .3s ease;width:36px}.ficha-modal .btn-close:hover{background:#ffffff4d}.modal-body-scrollable{background:#fff;max-height:70vh;overflow-y:auto;padding:30px}.form-grid-modern{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));width:100%}.form-grid-modern .form-group{display:flex;flex-direction:column;gap:8px}.form-grid-modern .form-group.full-width{grid-column:1/-1}.form-grid-modern .form-group label{color:#374151;font-size:14px;font-weight:600;margin-bottom:6px}.form-grid-modern .form-group input,.form-grid-modern .form-group select,.form-grid-modern .form-group textarea{background:#fff;border:1.5px solid #d1d5db;border-radius:8px;font-family:inherit;font-size:14px;padding:12px 16px;transition:all .3s ease}.form-grid-modern .form-group input:focus,.form-grid-modern .form-group select:focus,.form-grid-modern .form-group textarea:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.form-grid-modern .form-group.checkbox-group{align-items:center;flex-direction:row;gap:12px}.form-grid-modern .form-group.checkbox-group input[type=checkbox]{cursor:pointer;height:18px;margin:0;width:18px}.form-grid-modern .form-group.checkbox-group label{cursor:pointer;font-weight:500;margin:0}.form-actions{background:#f9fafb;border-radius:0 0 12px 12px;border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;margin:0 -30px -30px;padding:20px 30px}.form-actions .btn-secondary{background:#fff;border:1.5px solid #d1d5db;border-radius:8px;color:#374151;cursor:pointer;font-weight:500;padding:12px 24px;transition:all .3s ease}.form-actions .btn-secondary:hover{background:#f3f4f6;border-color:#9ca3af}.form-actions .btn-primary{background:linear-gradient(135deg,#2563eb,#3b82f6);border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;padding:12px 24px;transition:all .3s ease}.form-actions .btn-primary:hover{box-shadow:0 4px 12px #2563eb66;transform:translateY(-1px)}.modal-body-scrollable::-webkit-scrollbar{width:8px}.modal-body-scrollable::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.modal-body-scrollable::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.modal-body-scrollable::-webkit-scrollbar-thumb:hover{background:#94a3b8}@media (max-width:768px){.form-grid-modern{gap:20px;grid-template-columns:1fr}.modal-body-scrollable{max-height:75vh;padding:20px}.form-actions{flex-direction:column;gap:12px;margin:0 -20px -20px;padding:20px}}.zoom-controls-modern{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 4px 12px #0000001a;display:flex;gap:8px;padding:8px 16px}.zoom-btn.modern{align-items:center;background:#f9fafb;border:1px solid #d1d5db;border-radius:8px;color:#374151;cursor:pointer;display:flex;font-size:0;height:36px;justify-content:center;transition:all .2s ease;width:36px}.zoom-btn.modern:hover{background:#3b82f6;border-color:#3b82f6;box-shadow:0 4px 8px #3b82f640;color:#fff;transform:translateY(-1px)}.zoom-btn.reset-modern{align-items:center;background:#fef3c7;border:1px solid #f59e0b;border-radius:8px;color:#d97706;cursor:pointer;display:flex;height:36px;justify-content:center;margin-left:8px;transition:all .2s ease;width:36px}.zoom-btn.reset-modern:hover{background:#f59e0b;box-shadow:0 4px 8px #f59e0b40;color:#fff;transform:translateY(-1px)}.zoom-btn.print-modern{align-items:center;background:#d1fae5;border:1px solid #10b981;border-radius:8px;color:#047857;cursor:pointer;display:flex;height:36px;justify-content:center;margin-left:8px;transition:all .2s ease;width:36px}.zoom-btn.print-modern:hover{background:#10b981;box-shadow:0 4px 8px #10b98140;color:#fff;transform:translateY(-1px)}.zoom-display{background:#f3f4f6;border-radius:6px;margin:0 4px;padding:8px 16px}.zoom-percentage{color:#374151;display:inline-block;font-size:14px;font-weight:600;min-width:50px;text-align:center}.ficha-actions.modern-flex{border-top:1px solid #f0f0f0;display:flex;flex-direction:row;flex-wrap:nowrap;gap:16px;justify-content:center;margin-left:auto;margin-right:auto;margin-top:20px;max-width:600px;padding:16px}.ficha-actions.modern-flex .btn-action{flex:0 1 auto;min-width:140px;white-space:nowrap}.btn-action{align-items:center;border:1px solid;border-radius:8px;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:10px;justify-content:center;min-height:44px;min-width:120px;padding:12px 20px;transition:all .2s ease}.btn-action svg{flex-shrink:0;height:16px;width:16px}.btn-action span{font-size:13px;font-weight:500}.btn-action.primary-action{background:#eff6ff;border-color:#3b82f6;color:#1e40af}.btn-action.primary-action:hover{background:#3b82f6;box-shadow:0 4px 12px #3b82f640;color:#fff;transform:translateY(-1px)}.btn-action.success-action{background:#f0fdf4;border-color:#22c55e;color:#16a34a}.btn-action.success-action:hover{background:#22c55e;box-shadow:0 4px 12px #22c55e40;color:#fff;transform:translateY(-1px)}.btn-action.danger-action{background:#fef2f2;border-color:#ef4444;color:#dc2626}.btn-action.danger-action:hover{background:#ef4444;box-shadow:0 4px 12px #ef444440;color:#fff;transform:translateY(-1px)}.modern-modal-actions{background:#f9fafb;border-radius:0 0 12px 12px;border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:center;padding:20px}.btn-close-modal.modern,.btn-print.modern{align-items:center;background:#fff;border:1px solid;border-radius:8px;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:12px 24px;transition:all .2s ease}.btn-print.modern{border-color:#3b82f6;color:#1e40af}.btn-print.modern:hover{background:#3b82f6;box-shadow:0 4px 12px #3b82f640;color:#fff;transform:translateY(-1px)}.btn-close-modal.modern{border-color:#6b7280;color:#374151}.btn-close-modal.modern:hover{background:#6b7280;box-shadow:0 4px 12px #6b728040;color:#fff;transform:translateY(-1px)}.btn-close-modal.modern svg,.btn-print.modern svg{flex-shrink:0;height:16px;width:16px}.preview-controls{align-items:center;background:#f8fafc;border-bottom:1px solid #e2e8f0;display:flex;justify-content:center;padding:16px 20px;position:-webkit-sticky;position:sticky;top:0;z-index:10}.ficha-preview-container{background:#f5f5f5;max-height:70vh;overflow-y:auto;padding:20px}@media (max-width:768px){.zoom-controls-modern{gap:6px;padding:6px 12px}.zoom-btn.modern,.zoom-btn.print-modern,.zoom-btn.reset-modern{height:32px;width:32px}.ficha-actions.modern-flex{flex-direction:column;gap:8px}.btn-action{flex:none}.zoom-controls-modern{gap:6px;padding:6px 12px}.zoom-btn.modern,.zoom-btn.reset-modern{height:32px;width:32px}.modern-modal-actions{flex-direction:column;gap:8px}.btn-close-modal.modern,.btn-print.modern{justify-content:center;width:100%}}@keyframes buttonPress{0%{transform:translateY(0)}50%{transform:translateY(1px)}to{transform:translateY(0)}}.btn-action:active,.zoom-btn.modern:active,.zoom-btn.reset-modern:active{animation:buttonPress .1s ease}.user-form-container{background:#fff;border-radius:12px;overflow:hidden}.form-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid #e9ecef;color:#fff;display:flex;justify-content:space-between;padding:1.5rem 2rem}.form-header h2{font-size:1.5rem;font-weight:600;margin:0}.user-id-badge{background:#fff3;border-radius:20px;font-size:.85rem;font-weight:500;padding:.35rem .75rem}.tabs-container{background:#f8f9fa;border-bottom:2px solid #e9ecef;display:flex}.tab{align-items:center;background:#0000;border:none;color:#6c757d;cursor:pointer;display:flex;flex:1 1;font-size:.95rem;font-weight:500;gap:.5rem;justify-content:center;padding:1rem 1.5rem;position:relative;transition:all .2s}.tab:hover{background:#667eea0d;color:#667eea}.tab.active{background:#fff;color:#667eea}.tab.active:after{background:#667eea;bottom:-2px;content:"";height:2px;left:0;position:absolute;right:0}.tab-icon{font-size:1.1rem}.tab-label{font-weight:500}.form-content{min-height:400px;padding:2rem}.form-section{animation:fadeIn .3s ease-in-out}.form-row{grid-gap:1.5rem;gap:1.5rem;grid-template-columns:repeat(2,1fr);margin-bottom:1.5rem}.form-group label:after{color:#dc3545;content:" *";display:inline}.form-group input,.form-group select,.form-group textarea{background:#fff;border:1px solid #ced4da;border-radius:6px;font-family:inherit;font-size:.95rem;padding:.75rem;transition:all .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-group input:disabled,.form-group select:disabled{background:#e9ecef}.form-group input::placeholder{color:#adb5bd}.info-box{background:#f0f7ff;border-left:4px solid #667eea;border-radius:6px;margin-top:1.5rem;padding:1rem 1.25rem}.info-box strong{color:#495057;display:block;font-size:.95rem;margin-bottom:.75rem}.info-box ul{color:#6c757d;font-size:.9rem;margin:0;padding-left:1.25rem}.info-box li{margin-bottom:.5rem}.info-box li strong{color:#495057;display:inline}.form-footer{background:#f8f9fa;border-top:1px solid #e9ecef;display:flex;gap:1rem;justify-content:flex-end;padding:1.5rem 2rem}.btn-primary:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.btn-secondary{border:1px solid #ced4da;color:#6c757d}.btn-secondary:hover:not(:disabled){background:#e9ecef;border-color:#adb5bd}.form-group input.error,.form-group select.error{border-color:#dc3545}.form-group input.error:focus,.form-group select.error:focus{box-shadow:0 0 0 3px #dc35451a}.error-message{color:#dc3545;font-size:.85rem;margin-top:.25rem}@media (max-width:768px){.form-content{padding:1.5rem}.form-row{gap:1rem;grid-template-columns:1fr}.tabs-container{overflow-x:auto}.tab{flex:initial;min-width:150px}.tab-label{display:none}.form-header{align-items:flex-start;flex-direction:column;gap:.75rem}}.users-view{margin:0 auto;max-width:1600px;padding:2rem}.users-header{align-items:flex-start;display:flex;gap:2rem;justify-content:space-between;margin-bottom:2rem}.header-content h1{color:#1a1a1a;font-size:2rem;font-weight:600;margin:0 0 .5rem}.header-content p{color:#666;font-size:.95rem;margin:0}.alert{border-radius:8px;font-size:.95rem;gap:.75rem;margin-bottom:1.5rem;padding:1rem 1.5rem}.alert-error{background:#fee;border:1px solid #fcc;color:#c00}.alert-success{background:#efe;border:1px solid #cfc;color:#090}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.stat-card{border:1px solid #e5e5e5;box-shadow:0 2px 8px #0000000f}.stat-card:hover{box-shadow:0 4px 12px #0000001a}.stat-icon{font-size:2.5rem;height:64px;width:64px}.stat-total .stat-icon{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.stat-activos .stat-icon{background:linear-gradient(135deg,#48bb78,#38a169);color:#fff}.stat-admin .stat-icon{background:linear-gradient(135deg,#ed8936,#dd6b20);color:#fff}.stat-coordinador .stat-icon{background:linear-gradient(135deg,#4299e1,#3182ce);color:#fff}.stat-number{color:#1a1a1a;font-size:2rem;font-weight:700;line-height:1;margin-bottom:.25rem}.stat-label{color:#666;font-size:.875rem;font-weight:500}.stat-total{border-left:4px solid #667eea}.stat-activos{border-left:4px solid #48bb78}.stat-admin{border-left:4px solid #ed8936}.stat-coordinador{border-left:4px solid #4299e1}.table-container{border:1px solid #e5e5e5;border-radius:12px;box-shadow:0 2px 8px #0000000f;overflow:hidden}.users-table{border-collapse:collapse;width:100%}.users-table thead{background:#f8f9fa}.users-table th{border-bottom:2px solid #dee2e6;color:#495057;font-size:.875rem;font-weight:600;letter-spacing:.5px;padding:1rem 1.5rem;text-align:left;text-transform:uppercase}.users-table th:first-child{width:17%}.users-table th:nth-child(2){width:14%}.users-table th:nth-child(3),.users-table th:nth-child(4){width:9%}.users-table th:nth-child(5){width:14%}.users-table th:nth-child(6){width:9%}.users-table th:nth-child(7){width:8%}.users-table th:nth-child(8){width:20%}.users-table tbody tr{border-bottom:1px solid #e9ecef;transition:background .2s}.users-table tbody tr:hover{background:#f8f9fa}.users-table td{color:#212529;font-size:.95rem;padding:1rem 1.5rem;vertical-align:middle}.user-cell{gap:1rem;min-width:200px}.user-avatar,.user-cell{align-items:center;display:flex}.user-avatar{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;box-shadow:0 2px 6px #667eea4d;color:#fff;flex-shrink:0;font-size:1.15rem;font-weight:600;height:44px;justify-content:center;width:44px}.user-info{display:flex;flex:1 1;flex-direction:column;gap:.35rem;min-width:0}.user-name{color:#212529;font-size:.95rem;font-weight:600;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-id{color:#6c757d;font-size:.75rem;font-weight:500}.coordinacion-badge,.role-badge,.status-badge{align-items:center;border-radius:20px;display:inline-flex;font-size:.8rem;font-weight:500;padding:.35rem .75rem}.badge-admin{background:#fed7aa;color:#9c4221}.badge-coordinador{background:#bee3f8;color:#2c5282}.badge-usuario{background:#e2e8f0;color:#4a5568}.status-active{background:#c6f6d5;color:#22543d}.status-inactive{background:#fed7d7;color:#742a2a}.coordinacion-badge{background:#e6fffa;color:#234e52}.action-buttons{display:flex;flex-wrap:nowrap;gap:.4rem}.action-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;flex-shrink:0;font-size:.8rem;justify-content:center;min-width:32px;padding:.45rem .55rem;transition:all .2s}.action-btn.edit{background:#e3f2fd;color:#1976d2}.action-btn.edit:hover{background:#1976d2;color:#fff}.action-btn.password{background:#fff3e0;color:#e65100}.action-btn.password:hover{background:#e65100;color:#fff}.action-btn.deactivate{background:#ffebee;color:#c62828}.action-btn.deactivate:hover{background:#c62828;color:#fff}.action-btn.activate{background:#e8f5e9;color:#2e7d32}.action-btn.activate:hover{background:#2e7d32;color:#fff}.action-btn.delete{background:#fce4ec;color:#ad1457}.action-btn.delete:hover{background:#ad1457;color:#fff}.btn-primary,.btn-secondary{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:.95rem;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2)}.btn-primary:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.btn-secondary{background:#e2e8f0;color:#4a5568}.btn-secondary:hover{background:#cbd5e0}.empty-state{padding:4rem 2rem;text-align:center}.empty-icon{font-size:5rem;margin-bottom:1rem;opacity:.5}.empty-state h3{color:#212529;font-size:1.5rem;margin-bottom:.5rem}.empty-state p{color:#6c757d;margin-bottom:2rem}.loading-spinner{color:#6c757d;font-size:1.25rem;padding:4rem;text-align:center}.modal-overlay{background:#0009;padding:2rem}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:800px;overflow-y:auto;width:100%}.modal-content.password-modal{max-width:500px}.password-form{padding:2rem}.user-info-display{background:#f8f9fa;border-radius:8px;display:flex;flex-direction:column;gap:.25rem;margin-bottom:1.5rem;padding:1rem}.user-info-display strong{color:#212529;font-size:1.1rem}.user-email{color:#6c757d;font-size:.9rem}.modal-header{border-bottom:1px solid #e9ecef;padding:1.5rem 2rem}.modal-header h2{color:#212529;font-size:1.5rem;margin:0}.modal-close{align-items:center;background:none;border-radius:6px;color:#6c757d;display:flex;font-size:2rem;height:32px;justify-content:center;padding:0;width:32px}.modal-close:hover{background:#e9ecef;color:#212529}.form-group{margin-bottom:1.5rem}.form-group label{color:#495057;font-size:.9rem}.form-group input,.form-group select{border:1px solid #ced4da;border-radius:6px;padding:.75rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}@media (max-width:1200px){.users-table td:nth-child(5),.users-table th:nth-child(5){display:none}}@media (max-width:768px){.users-view{padding:1rem}.users-header{flex-direction:column}.stats-grid{grid-template-columns:repeat(2,1fr)}.users-table td:nth-child(3),.users-table td:nth-child(4),.users-table th:nth-child(3),.users-table th:nth-child(4){display:none}.action-buttons{flex-wrap:wrap}}.control-interno-container{margin:0 auto;max-width:1600px;padding:24px}.control-interno-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:24px}.control-interno-header h1{color:#1e293b;font-size:28px;font-weight:700;margin:0 0 8px}.subtitle{color:#64748b;font-size:14px;margin:0}.header-actions{gap:12px}.btn-clear-filters,.btn-filter,.btn-primary,.btn-secondary{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-family:inherit;font-size:14px;font-weight:600;gap:8px;padding:10px 18px;transition:all .2s}.btn-primary{box-shadow:0 2px 8px #3b82f64d}.btn-primary:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 12px #3b82f666;transform:translateY(-1px)}.btn-secondary{background:#fff;border:1.5px solid #cbd5e1;color:#475569}.btn-secondary:hover{background:#f8fafc;border-color:#94a3b8;transform:translateY(-1px)}.btn-filter{background:#fff;border:1.5px solid #cbd5e1;color:#475569}.btn-filter.active{background:#667eea;border-color:#667eea;color:#fff}.btn-clear-filters{background:#ef4444;border:none;color:#fff}.btn-clear-filters:hover{background:#dc2626;transform:translateY(-1px)}.stats-grid{grid-gap:20px;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:24px}.stat-card{box-shadow:0 2px 8px #00000014;gap:16px;padding:20px;transition:all .2s}.stat-card:hover{box-shadow:0 4px 16px #0000001f}.stat-icon{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;flex-shrink:0;font-size:22px;height:48px;width:48px}.stat-content{flex:1 1}.stat-content h3{color:#1e293b;font-size:16px;font-weight:600;margin:0 0 12px}.stat-numbers{display:flex;gap:16px;margin-bottom:12px}.stat-item{align-items:center;display:flex;font-size:13px;font-weight:500;gap:6px}.stat-item.success{color:#10b981}.stat-item.warning{color:#f59e0b}.stat-progress{margin-top:8px}.progress-bar{background:#e2e8f0;border-radius:10px;height:6px;margin-bottom:6px;overflow:hidden}.progress-fill{background:linear-gradient(90deg,#10b981,#059669);height:100%;transition:width .3s ease}.progress-label{color:#64748b;font-size:12px;font-weight:500}.control-interno-toolbar{margin-bottom:20px}.control-interno-toolbar,.search-bar{align-items:center;display:flex;gap:12px}.search-bar{background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;flex:1 1;padding:12px 16px;transition:all .2s}.search-bar:focus-within{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.search-icon{color:#94a3b8;font-size:16px}.search-bar input{border:none;color:#1e293b;flex:1 1;font-family:inherit;font-size:14px;outline:none}.search-bar input::placeholder{color:#94a3b8}.filters-panel{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:20px;padding:20px}.filters-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.filter-group{display:flex;flex-direction:column;gap:8px}.filter-group label{color:#475569;font-size:13px;font-weight:600}.form-control{border:1.5px solid #e2e8f0;border-radius:8px;font-family:inherit;padding:10px 12px}.form-control:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.control-interno-content{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden}.empty-state,.error-state,.loading-state{color:#64748b;padding:80px 20px;text-align:center}.loading-state .spinner{animation:spin .8s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#3b82f6;height:40px;margin:0 auto 16px;width:40px}.error-state{color:#ef4444}.error-state svg{font-size:48px;margin-bottom:16px}.empty-state svg{color:#cbd5e1;font-size:64px;margin-bottom:16px}.empty-state h3{color:#475569;font-size:18px;margin:0 0 8px}.empty-state p{color:#94a3b8;font-size:14px;margin:0 0 20px}.data-table{border-collapse:collapse;width:100%}.data-table thead{background:#f8fafc;border-bottom:2px solid #e2e8f0}.data-table th{color:#475569;font-size:13px;font-weight:600;letter-spacing:.5px;padding:14px 16px;text-align:left;text-transform:uppercase}.data-table td{border-bottom:1px solid #f1f5f9;color:#334155;font-size:14px;padding:16px}.data-table tbody tr{transition:background .2s}.data-table tbody tr:hover{background:#f8fafc}.employee-cell{align-items:center;display:flex;gap:12px}.employee-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:16px;height:40px;justify-content:center;width:40px}.employee-info{display:flex;flex-direction:column;gap:4px}.employee-name{color:#1e293b;font-weight:600}.employee-subtitle{color:#64748b;font-size:12px}.rfc-text{color:#475569;font-family:Courier New,monospace;font-size:13px;font-weight:500}.badge{border-radius:12px;font-weight:600;padding:4px 12px;text-transform:capitalize}.badge-primary{background:#dbeafe;color:#1e40af}.badge-secondary{background:#e2e8f0;color:#475569}.unidad-cell{align-items:center;color:#475569;display:flex;gap:8px}.unidad-cell svg{color:#667eea;font-size:14px}.dependencia-text{color:#64748b}.text-muted{color:#94a3b8;font-size:13px;font-style:italic}.conceptos-list{display:flex;flex-wrap:wrap;gap:8px}.concepto-badge{align-items:center;border-radius:16px;display:flex;font-size:12px;font-weight:500;gap:6px;padding:6px 12px;transition:all .2s}.concepto-badge.firmado{background:#d1fae5;border:1px solid #a7f3d0;color:#065f46}.concepto-badge.pendiente{background:#fef3c7;border:1px solid #fde68a;color:#92400e}.concepto-badge:hover{box-shadow:0 2px 6px #0000001a;transform:translateY(-1px)}.icon-success{color:#10b981;font-size:14px}.icon-warning{color:#f59e0b;font-size:14px}.concepto-nombre{font-weight:600}.concepto-fecha{font-size:11px;margin-left:4px;opacity:.8}.control-interno-footer{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;display:flex;justify-content:space-between;margin-top:20px;padding:20px 24px}.legend h4{color:#475569;font-size:14px;font-weight:600;margin:0 0 12px}.legend-items{display:flex;gap:20px}.legend-item{align-items:center;color:#64748b;display:flex;font-size:13px;gap:8px}.footer-stats{color:#64748b;font-size:14px;font-weight:500}@media (max-width:768px){.control-interno-container{padding:16px}.control-interno-header{flex-direction:column;gap:16px}.header-actions{flex-wrap:wrap;width:100%}.filters-grid,.stats-grid{grid-template-columns:1fr}.control-interno-toolbar{flex-direction:column}.table-container{overflow-x:scroll}.data-table{min-width:900px}.control-interno-footer{align-items:flex-start;flex-direction:column;gap:16px}.legend-items{flex-direction:column;gap:8px}}.confirmation-container{align-items:center;background-color:#f8fafc;display:flex;height:100vh;justify-content:center}.confirmation-card{background:#fff;border-radius:16px;box-shadow:0 10px 25px #0f172a1f;max-width:420px;padding:32px 40px;text-align:center}.confirmation-card h1{color:#0474b8;font-size:24px;margin-bottom:8px}.confirmation-card p{color:#64748b;margin:0}.loadtest-container{margin:0 auto;max-width:1400px;padding:2rem}.loadtest-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:2rem}.loadtest-header h1{align-items:center;color:#1f2937;display:flex;font-size:2rem;gap:.75rem;margin-bottom:.5rem}.loadtest-header .subtitle{color:#6b7280;font-size:.95rem}.header-actions{display:flex;gap:.75rem}.stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.stat-card{align-items:center;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;display:flex;gap:1rem;padding:1.5rem;transition:transform .2s,box-shadow .2s}.stat-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.stat-icon{align-items:center;border-radius:12px;color:#fff;display:flex;font-size:1.5rem;height:60px;justify-content:center;width:60px}.stat-icon.primary{background:linear-gradient(135deg,#3b82f6,#2563eb)}.stat-icon.success{background:linear-gradient(135deg,#10b981,#059669)}.stat-icon.warning{background:linear-gradient(135deg,#f59e0b,#d97706)}.stat-icon.purple{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.stat-content h3{color:#1f2937;font-size:1.75rem;font-weight:700;margin-bottom:.25rem}.stat-content p{color:#6b7280;font-size:.9rem;margin-bottom:.25rem}.stat-subtitle{color:#9ca3af;font-size:.8rem}.config-panel{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem;padding:2rem}.config-section{border-bottom:1px solid #e5e7eb;margin-bottom:2rem;padding-bottom:2rem}.config-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.config-section h3{align-items:center;color:#1f2937;display:flex;font-size:1.1rem;gap:.5rem;margin-bottom:1rem}.form-row{grid-gap:1rem;align-items:end;display:grid;gap:1rem;grid-template-columns:1fr 2fr auto}.form-row button{align-self:end;height:42px;margin:0;padding:.625rem 1.25rem;white-space:nowrap}.form-group{display:flex;flex-direction:column}.form-group label{color:#374151;font-size:.875rem;margin-bottom:.5rem;min-height:20px}.form-group input,.form-group select{border:1px solid #d1d5db;border-radius:8px;font-size:.95rem;height:42px;padding:.625rem .875rem;transition:border-color .2s,box-shadow .2s;width:100%}.form-group small{display:block;margin-top:.25rem;min-height:0}.form-group input:focus,.form-group select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-group input:disabled,.form-group select:disabled{background-color:#f3f4f6;cursor:not-allowed;opacity:.6}.btn-danger,.btn-outline,.btn-primary,.btn-secondary,.btn-success{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:.95rem;font-weight:500;gap:.5rem;padding:.625rem 1.25rem;transition:all .2s}.btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb)}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 12px #3b82f64d;transform:translateY(-1px)}.btn-success{background:linear-gradient(135deg,#10b981,#059669)}.btn-success:hover:not(:disabled){background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 12px #10b9814d;transform:translateY(-1px)}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626)}.btn-danger:hover:not(:disabled){background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 4px 12px #ef44444d;transform:translateY(-1px)}.btn-secondary{background:#f3f4f6;color:#374151}.btn-secondary:hover:not(:disabled){background:#e5e7eb}.btn-outline{background:#fff;border:1px solid #3b82f6;color:#3b82f6}.btn-outline:hover:not(:disabled){background:#eff6ff}button:disabled{cursor:not-allowed;opacity:.6}.results-panel{animation:slideIn .3s ease;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:2rem}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.results-panel h2{color:#1f2937;font-size:1.5rem;margin-bottom:1.5rem}.error-message{background:#fee2e2;border-left:4px solid #ef4444;border-radius:8px;color:#991b1b;padding:1rem}.metrics-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.metric-card{background:linear-gradient(135deg,#f9fafb,#f3f4f6);border:1px solid #e5e7eb;border-radius:12px;padding:1.5rem;text-align:center}.metric-card h3{color:#6b7280;font-size:.85rem;letter-spacing:.5px;margin-bottom:.75rem;text-transform:uppercase}.metric-value{color:#1f2937;font-size:2rem;font-weight:700;margin-bottom:.5rem}.metric-value.success{color:#10b981}.metric-value.error{color:#ef4444}.metric-label{color:#9ca3af;font-size:.85rem}.latency-breakdown{border-top:1px solid #e5e7eb;margin-top:2rem;padding-top:2rem}.latency-breakdown h3{color:#1f2937;font-size:1.1rem;margin-bottom:1rem}.breakdown-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.breakdown-item{background:#f9fafb;border-radius:8px;display:flex;flex-direction:column;gap:.5rem;padding:1rem}.breakdown-label{color:#6b7280;font-size:.8rem;font-weight:500}.breakdown-value{color:#1f2937;font-size:1.25rem;font-weight:700}@media (max-width:768px){.loadtest-container{padding:1rem}.loadtest-header{flex-direction:column;gap:1rem}.header-actions{flex-direction:column;width:100%}.header-actions button{justify-content:center;width:100%}.stats-grid{grid-template-columns:1fr}.form-row{flex-direction:column}.form-group{min-width:100%}.charts-section,.metrics-grid{grid-template-columns:1fr}}.charts-section{grid-gap:2rem;border-top:1px solid #e5e7eb;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin-top:2rem;padding-top:2rem}.chart-container{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;padding:1.5rem}.chart-container h3{color:#1f2937;font-size:1.1rem;margin-bottom:1rem;text-align:center}.App{background:linear-gradient(180deg,#f8fafc,#f1f5f9);min-height:100vh}.container{max-width:1600px;padding:16px}.page-header{margin-bottom:16px}.page-header h1{color:#1e293b;font-size:18px;font-weight:600;letter-spacing:-.02em;margin-bottom:6px}.page-header p{color:#64748b}.btn,.page-header p{font-size:12px;line-height:1.5}.btn{align-items:center;border:1px solid #0000;border-radius:6px;box-shadow:0 1px 2px 0 #0000000d;cursor:pointer;display:inline-flex;font-weight:500;gap:6px;justify-content:center;padding:7px 14px;transition:all .2s;white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.6}.btn:focus{ring:2px;ring-offset:2px;outline:none}.btn-primary{background-color:#6366f1;border-color:#6366f1;color:#fff}.btn-primary:hover:not(:disabled){background-color:#4f46e5;border-color:#4f46e5;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f}.btn-primary:focus{ring-color:#6366f180}.btn-primary:active:not(:disabled){background-color:#4338ca}.btn-success{background-color:#34d399;border-color:#34d399;color:#fff}.btn-success:hover:not(:disabled){background-color:#10b981;border-color:#10b981;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f}.btn-success:focus{ring-color:#34d39980}.btn-danger{background-color:#f87171;border-color:#f87171;color:#fff}.btn-danger:hover:not(:disabled){background-color:#dc2626;border-color:#dc2626;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f}.btn-danger:focus{ring-color:#f8717180}.btn-warning{background-color:#fbbf24;border-color:#fbbf24;color:#fff}.btn-warning:hover:not(:disabled){background-color:#f59e0b;border-color:#f59e0b;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f}.btn-warning:focus{ring-color:#fbbf2480}.btn-ghost{background-color:initial;border-color:#0000;box-shadow:none;color:#64748b}.btn-ghost:hover:not(:disabled){background-color:#f8fafc;color:#1e293b}.btn-icon{min-height:36px;min-width:36px;padding:8px}.btn-lg{font-size:15px;min-height:44px;padding:12px 24px}.btn-icon.btn-sm{min-height:32px;min-width:32px;padding:6px}.btn-danger.btn-icon.btn-sm,.btn-secondary.btn-icon.btn-sm{padding:6px}.btn-icon.btn-lg{min-height:44px;min-width:44px;padding:10px}.card{border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 1px 2px 0 #0000000d;margin-bottom:20px;padding:20px;transition:all .2s}.card:hover{box-shadow:0 4px 6px -1px #0000001a}.card-header{background:#f8fafc;border-bottom:1px solid #e2e8f0;border-radius:8px 8px 0 0;margin:-20px -20px 20px;padding:16px 20px}.card-title{color:#1e293b;font-size:18px;font-weight:600}.card-body{padding:20px}.form-group{margin-bottom:20px}.form-group label{color:#475569;display:block;font-size:14px;font-weight:500;margin-bottom:8px}.form-control{background:#fff;border:1px solid #e2e8f0;border-radius:6px;color:#1e293b;font-size:14px;padding:10px 14px;transition:all .2s;width:100%}.form-control::placeholder{color:#94a3b8}.form-control:focus{ring:2px;ring-color:#6366f133;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;outline:none}.form-control:disabled{background:#f8fafc;color:#94a3b8;cursor:not-allowed}select.form-control{cursor:pointer}textarea.form-control{min-height:100px;resize:vertical}.table-container{background:#fff;border:1px solid #e2e8f0;border-radius:8px;overflow-x:auto}.table{background:#fff;border-collapse:collapse;width:100%}.table thead{background:#f8fafc;border-bottom:1px solid #e2e8f0}.table th{color:#64748b;font-size:12px;font-weight:600;letter-spacing:.05em;padding:8px 12px;text-align:left;text-transform:uppercase}.table td{border-bottom:1px solid #f1f5f9;color:#475569;font-size:13px;padding:8px 12px}.table tbody tr{transition:all .2s}.table tbody tr:hover{background-color:#f8fafc}.table tbody tr:last-child td{border-bottom:none}.badge{align-items:center;border:1px solid;border-radius:6px;display:inline-flex;font-size:12px;font-weight:500;padding:3px 8px}.badge-success{background-color:#d1fae5!important;border-color:#a7f3d0!important;color:#065f46!important}.badge-warning{background-color:#fef3c7!important;border-color:#fde68a!important;color:#92400e!important}.badge-danger{background-color:#fee2e2!important;border-color:#fecaca!important;color:#991b1b!important}.badge-info{background-color:#dbeafe!important;border-color:#bfdbfe!important;color:#1e40af!important}.badge-secondary{background-color:#f1f5f9!important;border-color:#e2e8f0!important;color:#475569!important}.loading{align-items:center;display:flex;justify-content:center;padding:40px}.spinner{animation:spin .8s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#6366f1;height:40px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.modal-overlay{align-items:center;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a66;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{animation:slideUp .2s ease-out;background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-height:90vh;max-width:600px;overflow-y:auto;padding:28px;width:90%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:16px}.modal-title{color:#1e293b;font-size:20px;font-weight:600}.modal-close{background:#0000;border:none;border-radius:4px;color:#64748b;cursor:pointer;font-size:20px;padding:4px;transition:all .2s}.modal-close:hover{background:#f1f5f9;color:#1e293b}.modal-footer{border-top:1px solid #e2e8f0;display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:16px}.grid{grid-gap:20px;display:grid;gap:20px}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media (max-width:1024px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.text-center{text-align:center}.text-right{text-align:right}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mt-4{margin-top:32px}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.mb-4{margin-bottom:32px}.flex{display:flex}.flex-between{justify-content:space-between}.flex-between,.flex-center{align-items:center;display:flex}.flex-center{justify-content:center}.gap-1{gap:8px}.gap-2{gap:16px}.gap-3{gap:24px}.alert{align-items:center;border:1px solid;border-radius:6px;display:flex;font-size:14px;gap:12px;margin-bottom:20px;padding:14px 16px}.alert-success{background:#d1fae5;border-color:#a7f3d0;color:#065f46}.alert-warning{background:#fef3c7;border-color:#fde68a;color:#92400e}.alert-danger{background:#fee2e2;border-color:#fecaca;color:#991b1b}.alert-info{background:#dbeafe;border-color:#bfdbfe;color:#1e40af}.fab{align-items:center;background:#6366f1;border:none;border-radius:8px;bottom:24px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;color:#fff;cursor:pointer;display:flex;height:56px;justify-content:center;position:fixed;right:24px;transition:all .2s;width:56px;z-index:100}.fab:hover{background:#4f46e5;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;transform:scale(1.05)}@media (max-width:768px){.container{padding:16px}.page-header h1{font-size:20px}.card{padding:16px}.card-header{margin:-16px -16px 16px;padding:12px 16px}.modal{padding:20px;width:95%}.table td,.table th{padding:10px 12px}.fab{bottom:16px;height:48px;right:16px;width:48px}}.privacy-page{background:#f6f8fb;color:#0f172a;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial;min-height:calc(100vh - 80px);padding:48px 16px 96px}.container{margin:0 auto;max-width:1100px}.hero{background:linear-gradient(135deg,#4f46e5,#06b6d4);border-radius:12px;box-shadow:0 8px 30px #0f172a1f;color:#fff;padding:36px}.hero h1{font-size:1.9rem;letter-spacing:-.02em;margin:0 0 8px}.hero p{margin:0;opacity:.95}.content{grid-gap:28px;align-items:start;display:grid;gap:28px;grid-template-columns:1fr 300px;margin-top:24px}.card{background:#fff;border-radius:12px;box-shadow:0 6px 18px #0f172a0f;padding:22px}.section h2{color:#0f172a;margin-top:0}.section li,.section p{color:#374151;line-height:1.7}.toc{position:-webkit-sticky;position:sticky;top:110px}.toc-box{background:#0000;border-radius:10px;padding:12px}.toc ul{list-style:none;margin:0;padding:0}.toc a{border-radius:8px;color:#334155;display:block;padding:8px 10px;text-decoration:none;transition:background .15s ease}.toc a:hover{background:#f1f5f9}.small{color:#64748b;display:block;font-size:.9rem;margin-top:18px;text-align:right}@media (max-width:900px){.content{grid-template-columns:1fr}.toc{display:none}.hero h1{font-size:1.6rem}}
/*# sourceMappingURL=main.ae058191.css.map*/