:root{--toastify-color-light:#fff;--toastify-color-dark:#121212;--toastify-color-info:#3498db;--toastify-color-success:#07bc0c;--toastify-color-warning:#f1c40f;--toastify-color-error:hsl(6,78%,57%);--toastify-color-transparent:rgba(255,255,255,0.7);--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-container-width:fit-content;--toastify-toast-width:320px;--toastify-toast-offset:16px;--toastify-toast-top:max(var(--toastify-toast-offset),env(safe-area-inset-top));--toastify-toast-right:max(var(--toastify-toast-offset),env(safe-area-inset-right));--toastify-toast-left:max(var(--toastify-toast-offset),env(safe-area-inset-left));--toastify-toast-bottom:max(var(--toastify-toast-offset),env(safe-area-inset-bottom));--toastify-toast-background:#fff;--toastify-toast-padding:14px;--toastify-toast-min-height:64px;--toastify-toast-max-height:800px;--toastify-toast-bd-radius:6px;--toastify-toast-shadow:0px 4px 12px rgba(0,0,0,0.1);--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-color-progress-bgo:0.2}.Toastify__toast-container{z-index:var(--toastify-z-index);-webkit-transform:translateZ(var(--toastify-z-index));position:fixed;width:var(--toastify-container-width);box-sizing:border-box;color:#fff;display:flex;flex-direction:column}.Toastify__toast-container--top-left{top:var(--toastify-toast-top);left:var(--toastify-toast-left)}.Toastify__toast-container--top-center{top:var(--toastify-toast-top);left:50%;transform:translateX(-50%);align-items:center}.Toastify__toast-container--top-right{top:var(--toastify-toast-top);right:var(--toastify-toast-right);align-items:end}.Toastify__toast-container--bottom-left{bottom:var(--toastify-toast-bottom);left:var(--toastify-toast-left)}.Toastify__toast-container--bottom-center{bottom:var(--toastify-toast-bottom);left:50%;transform:translateX(-50%);align-items:center}.Toastify__toast-container--bottom-right{bottom:var(--toastify-toast-bottom);right:var(--toastify-toast-right);align-items:end}.Toastify__toast{--y:0;position:relative;touch-action:none;width:var(--toastify-toast-width);min-height:var(--toastify-toast-min-height);box-sizing:border-box;margin-bottom:1rem;padding:var(--toastify-toast-padding);border-radius:var(--toastify-toast-bd-radius);box-shadow:var(--toastify-toast-shadow);max-height:var(--toastify-toast-max-height);font-family:var(--toastify-font-family);z-index:0;display:flex;flex:1 1 auto;align-items:center;word-break:break-word}@media only screen and (max-width:480px){.Toastify__toast-container{width:100vw;left:env(safe-area-inset-left);margin:0}.Toastify__toast-container--top-center,.Toastify__toast-container--top-left,.Toastify__toast-container--top-right{top:env(safe-area-inset-top);transform:translateX(0)}.Toastify__toast-container--bottom-center,.Toastify__toast-container--bottom-left,.Toastify__toast-container--bottom-right{bottom:env(safe-area-inset-bottom);transform:translateX(0)}.Toastify__toast-container--rtl{right:env(safe-area-inset-right);left:auto}.Toastify__toast{--toastify-toast-width:100%;margin-bottom:0;border-radius:0}}.Toastify__toast-container[data-stacked=true]{width:var(--toastify-toast-width)}.Toastify__toast--stacked{position:absolute;width:100%;transform:translate3d(0,var(--y),0) scale(var(--s));transition:transform .3s}.Toastify__toast--stacked[data-collapsed] .Toastify__close-button,.Toastify__toast--stacked[data-collapsed] .Toastify__toast-body{transition:opacity .1s}.Toastify__toast--stacked[data-collapsed=false]{overflow:visible}.Toastify__toast--stacked[data-collapsed=true]:not(:last-child)>*{opacity:0}.Toastify__toast--stacked:after{content:"";position:absolute;left:0;right:0;height:calc(var(--g) * 1px);bottom:100%}.Toastify__toast--stacked[data-pos=top]{top:0}.Toastify__toast--stacked[data-pos=bot]{bottom:0}.Toastify__toast--stacked[data-pos=bot].Toastify__toast--stacked:before{transform-origin:top}.Toastify__toast--stacked[data-pos=top].Toastify__toast--stacked:before{transform-origin:bottom}.Toastify__toast--stacked:before{content:"";position:absolute;left:0;right:0;bottom:0;height:100%;transform:scaleY(3);z-index:-1}.Toastify__toast--rtl{direction:rtl}.Toastify__toast--close-on-click{cursor:pointer}.Toastify__toast-icon{-webkit-margin-end:10px;margin-inline-end:10px;width:22px;flex-shrink:0;display:flex}.Toastify--animate{animation-fill-mode:both;animation-duration:.5s}.Toastify--animate-icon{animation-fill-mode:both;animation-duration:.3s}.Toastify__toast-theme--dark{background:var(--toastify-color-dark);color:var(--toastify-text-color-dark)}.Toastify__toast-theme--colored.Toastify__toast--default,.Toastify__toast-theme--light{background:var(--toastify-color-light);color:var(--toastify-text-color-light)}.Toastify__toast-theme--colored.Toastify__toast--info{color:var(--toastify-text-color-info);background:var(--toastify-color-info)}.Toastify__toast-theme--colored.Toastify__toast--success{color:var(--toastify-text-color-success);background:var(--toastify-color-success)}.Toastify__toast-theme--colored.Toastify__toast--warning{color:var(--toastify-text-color-warning);background:var(--toastify-color-warning)}.Toastify__toast-theme--colored.Toastify__toast--error{color:var(--toastify-text-color-error);background:var(--toastify-color-error)}.Toastify__progress-bar-theme--light{background:var(--toastify-color-progress-light)}.Toastify__progress-bar-theme--dark{background:var(--toastify-color-progress-dark)}.Toastify__progress-bar--info{background:var(--toastify-color-progress-info)}.Toastify__progress-bar--success{background:var(--toastify-color-progress-success)}.Toastify__progress-bar--warning{background:var(--toastify-color-progress-warning)}.Toastify__progress-bar--error{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:var(--toastify-color-transparent)}.Toastify__close-button{color:#fff;position:absolute;top:6px;right:6px;background:transparent;outline:none;border:none;padding:0;cursor:pointer;opacity:.7;transition:.3s ease;z-index:1}.Toastify__toast--rtl .Toastify__close-button{left:6px;right:unset}.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{position:absolute;bottom:0;left:0;width:100%;height:100%;z-index:1;opacity:.7;transform-origin:left}.Toastify__progress-bar--animated{animation:Toastify__trackProgress linear 1 forwards}.Toastify__progress-bar--controlled{transition:transform .2s}.Toastify__progress-bar--rtl{right:0;left:auto;transform-origin:right;border-bottom-left-radius:0}.Toastify__progress-bar--wrp{position:absolute;overflow:hidden;bottom:0;left:0;width:100%;height:5px;border-bottom-left-radius:var(--toastify-toast-bd-radius);border-bottom-right-radius:var(--toastify-toast-bd-radius)}.Toastify__progress-bar--wrp[data-hidden=true]{opacity:0}.Toastify__progress-bar--bg{opacity:var(--toastify-color-progress-bgo);width:100%;height:100%}.Toastify__spinner{width:20px;height:20px;box-sizing:border-box;border:2px solid;border-radius:100%;border-color:var(--toastify-spinner-color-empty-area);border-right-color:var(--toastify-spinner-color);animation:Toastify__spin .65s linear infinite}@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,var(--y),0)}to{opacity:0;transform:translate3d(2000px,var(--y),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,var(--y),0)}to{opacity:0;transform:translate3d(-2000px,var(--y),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,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 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,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 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:translate3d(0,var(--y),0) 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%{transform:perspective(400px) rotateX(90deg);animation-timing-function:ease-in;opacity:0}40%{transform:perspective(400px) rotateX(-20deg);animation-timing-function:ease-in}60%{transform:perspective(400px) rotateX(10deg);opacity:1}80%{transform:perspective(400px) rotateX(-5deg)}to{transform:perspective(400px)}}@keyframes Toastify__flipOut{0%{transform:translate3d(0,var(--y),0) perspective(400px)}30%{transform:translate3d(0,var(--y),0) perspective(400px) rotateX(-20deg);opacity:1}to{transform:translate3d(0,var(--y),0) perspective(400px) rotateX(90deg);opacity:0}}.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:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInLeft{0%{transform:translate3d(-110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInUp{0%{transform:translate3d(0,110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInDown{0%{transform:translate3d(0,-110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideOutRight{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(110%,var(--y),0)}}@keyframes Toastify__slideOutLeft{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(-110%,var(--y),0)}}@keyframes Toastify__slideOutDown{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(0,500px,0)}}@keyframes Toastify__slideOutUp{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(0,-500px,0)}}.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;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--bottom-right,.Toastify__slide-exit--top-right{animation-name:Toastify__slideOutRight;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--top-center{animation-name:Toastify__slideOutUp;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--bottom-center{animation-name:Toastify__slideOutDown;animation-timing-function:ease-in;animation-duration:.3s}@keyframes Toastify__spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}*{margin:0;padding:0}html{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}body{background:linear-gradient(135deg,#eff6ff,#e0e7ff);color:#333;min-height:100vh;line-height:1.6}.flex{display:flex}.flex-col{flex-direction:column}.flex-1{flex:1 1}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.text-center{text-align:center}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.w-full{width:100%}.h-screen{height:100vh}.min-h-screen{min-height:100vh}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.hidden{display:none}.space-y-4>*+*{margin-top:1rem}.space-y-6>*+*{margin-top:1.5rem}.space-y-8>*+*{margin-top:2rem}.space-x-3>*+*{margin-left:.75rem}.space-x-4>*+*{margin-left:1rem}.gap-6{gap:1.5rem}.gap-4{gap:1rem}.gap-2{gap:.5rem}.dashboard-container{display:flex;height:100vh;background:rgba(239,246,255,.3)}.sidebar{transition:width .3s ease}.sidebar-header{padding:24px;border-bottom:1px solid rgba(255,255,255,.15)}.sidebar-logo{gap:12px}.logo-icon,.sidebar-logo{display:flex;align-items:center}.logo-icon{width:40px;height:40px;background:rgba(255,255,255,.2);border-radius:12px;justify-content:center;font-size:1.5rem}.logo-text h2{font-size:1.25rem;font-weight:700;color:#e1effe;margin-bottom:4px}.logo-text p{font-size:.875rem;color:#bfdbfe}.user-info{padding:24px;text-align:center;border-bottom:1px solid rgba(255,255,255,.15)}.user-avatar{width:64px;height:64px;background:linear-gradient(135deg,#60a5fa,#3b82f6);border-radius:50%;margin:0 auto 12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;border:4px solid rgba(255,255,255,.2)}.user-name{color:#e1effe;font-weight:600;margin-bottom:8px}.nav-menu{padding:16px 0;flex:1 1}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 24px;margin:2px 0;cursor:pointer;transition:all .3s ease;color:#bfdbfe;text-decoration:none;border:none;background:none;width:100%;text-align:left;font-size:.95rem}.nav-item:hover{transform:translateX(5px)}.nav-item.active,.nav-item:hover{border-left-color:#60a5fa;color:white}.nav-item.active{background:rgba(255,255,255,.18);box-shadow:0 2px 10px rgba(96,165,250,.3)}.nav-icon{width:20px;height:20px;flex-shrink:0}.logout-section{padding:16px;border-top:1px solid rgba(255,255,255,.15)}.logout-btn{width:100%;display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:12px;background:none;border:none;color:#bfdbfe;cursor:pointer;transition:all .3s ease;font-size:.95rem}.logout-btn:hover{background:rgba(239,68,68,.2);color:#fca5a5}.header{background:linear-gradient(135deg,#ffffff,#f8faff);padding:24px 32px;box-shadow:0 4px 20px rgba(30,58,138,.1);display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #e0e7ff}.header h1{color:#1e3a8a;font-size:1.875rem;font-weight:700;margin:0}.header-actions{display:flex;gap:16px}.main-content{display:flex;flex-direction:column}.content{flex:1 1;padding:32px;overflow-y:auto}.btn{padding:12px 24px;border:none;border-radius:12px;cursor:pointer;font-weight:600;transition:all .3s ease;box-shadow:0 2px 8px rgba(0,0,0,.1);display:inline-flex;align-items:center;justify-content:center;gap:8px;text-decoration:none;font-size:.95rem;line-height:1}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#1e40af,#1e3a8a);color:white}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#1d4ed8,#1e40af);transform:translateY(-2px);box-shadow:0 4px 15px rgba(30,64,175,.3)}.btn-secondary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:white}.btn-secondary:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-2px);box-shadow:0 4px 15px rgba(59,130,246,.3)}.btn-outline{border:2px solid #2563eb;background:transparent;color:#2563eb}.btn-outline:hover:not(:disabled){background:#eff6ff}.btn-sm{padding:8px 16px;font-size:.875rem;border-radius:8px}.btn-lg{padding:16px 32px;font-size:1.1rem;border-radius:14px}.card{background:linear-gradient(135deg,#ffffff,#f8faff);border-radius:16px;box-shadow:0 6px 25px rgba(30,58,138,.08);border:1px solid #e0e7ff;transition:all .3s ease}.card-hover:hover{transform:translateY(-8px);box-shadow:0 12px 35px rgba(30,58,138,.15)}.card-header{padding:24px 24px 0}.card-content{padding:24px}.card-content.no-padding{padding:0}.badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:20px;font-size:.75rem;font-weight:600}.badge-admin{background:linear-gradient(135deg,#1e40af,#1e3a8a);color:white;box-shadow:0 2px 8px rgba(30,64,175,.3)}.badge-user{background:linear-gradient(135deg,#3b82f6,#2563eb);color:white;box-shadow:0 2px 8px rgba(59,130,246,.3)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));grid-gap:24px;gap:24px;margin-bottom:32px}.stat-card{background:linear-gradient(135deg,#ffffff,#f8faff);padding:24px;border-radius:16px;box-shadow:0 6px 25px rgba(30,58,138,.08);transition:all .3s ease;border:1px solid #e0e7ff}.stat-card:hover{transform:translateY(-8px);box-shadow:0 12px 35px rgba(30,58,138,.15)}.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:white;box-shadow:0 4px 12px rgba(0,0,0,.2);margin-bottom:16px}.icon-documents{background:linear-gradient(135deg,#1e40af,#1e3a8a)}.icon-folders{background:linear-gradient(135deg,#3b82f6,#2563eb)}.icon-users{background:linear-gradient(135deg,#6366f1,#4f46e5)}.icon-storage{background:linear-gradient(135deg,#0ea5e9,#0284c7)}.stat-number{font-size:2rem;font-weight:800;color:#1e3a8a;background:linear-gradient(135deg,#1e40af,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:8px}.stat-label{color:#666;font-size:.9rem;font-weight:600}.section-title{font-size:1.25rem;margin-bottom:20px;color:#1e3a8a;font-weight:700}.activity-item{display:flex;align-items:center;gap:16px;padding:16px 0;border-bottom:1px solid #e0e7ff;transition:all .3s ease}.activity-item:hover{background:rgba(96,165,250,.05);border-radius:8px;padding:16px 12px}.activity-item:last-child{border-bottom:none}.activity-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;color:white;box-shadow:0 3px 10px rgba(0,0,0,.15);flex-shrink:0}.activity-content{flex:1 1}.activity-title{font-weight:600;margin-bottom:4px;color:#1e3a8a}.activity-time{color:#64748b;font-size:.875rem}.role-toggle{position:fixed;top:16px;right:16px;z-index:1000}.form-container{min-height:100vh;background:linear-gradient(135deg,#eff6ff,#e0e7ff 50%,#f3e8ff);display:flex;align-items:center;justify-content:center;padding:16px}.form-wrapper{width:100%;max-width:400px}.form-logo{text-align:center;margin-bottom:32px}.form-logo-icon{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:white;border-radius:16px;margin-bottom:16px;box-shadow:0 8px 25px rgba(37,99,235,.3);font-size:2rem}.form-logo h1{font-size:2rem;font-weight:800;color:#1f2937;margin-bottom:8px}.form-logo p{color:#6b7280;font-size:1rem}.form-card{background:linear-gradient(135deg,#ffffff,#f8faff);border-radius:20px;box-shadow:0 20px 50px rgba(30,58,138,.15);border:1px solid #e0e7ff;overflow:hidden}.form-header{padding:32px 32px 0;text-align:center}.form-header h2{font-size:1.75rem;font-weight:700;color:#1f2937;margin-bottom:8px}.form-header p{color:#6b7280;font-size:.95rem}.form-content{padding:32px}.form-group{margin-bottom:20px}.form-label{display:block;font-size:.875rem;font-weight:600;color:#374151;margin-bottom:8px}.form-input{width:100%;padding:12px 16px;border:2px solid #d1d5db;border-radius:12px;font-size:.95rem;transition:all .3s ease;background:white}.form-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.1)}.form-input-icon{position:relative}.form-input-icon input{padding-left:48px}.form-input-icon .icon-left{left:16px;pointer-events:none}.form-input-icon .icon-left,.form-input-icon .icon-right{position:absolute;top:50%;transform:translateY(-50%);color:#9ca3af;font-size:1.25rem}.form-input-icon .icon-right{right:16px;cursor:pointer;transition:color .3s ease}.form-input-icon .icon-right:hover{color:#6b7280}.alert{padding:16px;border-radius:8px;margin-bottom:20px}.alert-error{background:#fef2f2;border-left:4px solid #ef4444;color:#dc2626}.alert-info{background:#eff6ff;border-left:4px solid #3b82f6;color:#1d4ed8}.alert p{margin:0;font-size:.875rem}.form-footer{text-align:center;margin-top:24px;padding-top:24px;border-top:1px solid #e5e7eb}.form-footer p{color:#6b7280;font-size:.875rem}.form-footer a{color:#2563eb;text-decoration:none;font-weight:600;transition:color .3s ease}.form-footer a:hover{color:#1d4ed8}.form-copyright{text-align:center;margin-top:32px}.form-copyright p{color:#9ca3af;font-size:.75rem}.loading-container{min-height:100vh;background:linear-gradient(135deg,#eff6ff,#e0e7ff);display:flex;align-items:center;justify-content:center}.loading-content{text-align:center}.spinner{width:64px;height:64px;border:4px solid #e5e7eb;border-top-color:#2563eb;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-text{color:#2563eb;font-weight:600;font-size:1.1rem}@media (max-width:768px){.sidebar{width:250px}.stats-grid{grid-template-columns:1fr}.header{padding:16px 24px}.header h1{font-size:1.5rem}.content{padding:24px 16px}.header-actions{flex-direction:column;gap:8px}.btn{font-size:.875rem;padding:10px 20px}}@media (max-width:480px){.sidebar{width:200px}.form-content{padding:24px 20px}.form-header{padding:24px 20px 0}}.sidebar-header-compact,.user-info-compact{padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.15)}.user-info-compact{display:flex;align-items:center;gap:12px}.user-avatar-small{width:48px;height:48px;background:linear-gradient(135deg,#60a5fa,#3b82f6);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.25rem;border:3px solid rgba(255,255,255,.2);flex-shrink:0}.user-details{flex:1 1;min-width:0}.user-details .user-name{color:#e1effe;font-weight:600;margin-bottom:6px;font-size:.9rem}.nav-menu-expanded{padding:8px 0;flex:1 1;overflow-y:auto;min-height:0}.nav-menu-expanded .nav-item{display:flex;align-items:center;gap:12px;padding:10px 20px;margin:1px 0;cursor:pointer;transition:all .3s ease;color:#bfdbfe;text-decoration:none;border:none;background:none;width:100%;text-align:left;font-size:.9rem;border-radius:0 8px 8px 0}.nav-menu-expanded .nav-item:hover{background:rgba(255,255,255,.12);border-left-color:#60a5fa;transform:translateX(3px);color:white}.nav-menu-expanded .nav-item.active{background:rgba(255,255,255,.18);border-left-color:#60a5fa;color:white;box-shadow:0 2px 10px rgba(96,165,250,.3);font-weight:600}.nav-menu-expanded .nav-icon{width:18px;height:18px;flex-shrink:0;font-size:.9rem}.logout-section-bottom{padding:12px 16px;border-top:1px solid rgba(255,255,255,.15);margin-top:auto}.logout-section-bottom .logout-btn{width:100%;display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;background:none;border:none;color:#bfdbfe;cursor:pointer;transition:all .3s ease;font-size:.9rem}.logout-section-bottom .logout-btn:hover{background:rgba(239,68,68,.2);color:#fca5a5;transform:translateY(-1px)}.user-details .badge{font-size:.7rem;padding:2px 8px}.sidebar{width:288px;background:linear-gradient(135deg,#1e40af,#1e3a8a);color:white;flex-shrink:0;box-shadow:2px 0 25px rgba(30,58,138,.2);display:flex;flex-direction:column;height:100vh;overflow:hidden}@media (max-width:768px){.sidebar{width:260px}.sidebar-header-compact,.user-info-compact{padding:12px 16px}.nav-menu-expanded .nav-item{padding:8px 16px;font-size:.85rem}}@media (max-width:480px){.sidebar{width:240px}.logo-text p{font-size:.75rem}.user-details .user-name{font-size:.85rem}}.sidebar-collapsed{width:80px}.sidebar-header-with-toggle{padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.15);display:flex;justify-content:space-between;align-items:center;min-height:80px}.sidebar-collapsed .sidebar-header-with-toggle{padding:16px 12px;justify-content:center}.logo-icon-only{width:40px;height:40px;background:rgba(255,255,255,.2);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin:0 auto}.hamburger-btn{background:none;border:none;cursor:pointer;padding:8px;border-radius:6px;transition:background-color .3s ease}.hamburger-btn:hover{background:rgba(255,255,255,.1)}.hamburger-icon{width:20px;height:16px;position:relative;display:flex;flex-direction:column;justify-content:space-between}.hamburger-icon span{display:block;height:2px;width:100%;background:white;border-radius:1px;transition:all .3s ease}.hamburger-collapsed span:first-child{transform:rotate(45deg) translate(6px,6px)}.hamburger-collapsed span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}.user-info-collapsed{padding:16px 12px;border-bottom:1px solid rgba(255,255,255,.15);display:flex;justify-content:center}.nav-menu-fixed{padding:8px 0;flex:1 1;overflow-y:auto;overflow-x:hidden;min-height:0;scrollbar-width:none;-ms-overflow-style:none}.nav-menu-fixed::-webkit-scrollbar{display:none}.nav-menu-fixed .nav-item{display:flex;align-items:center;gap:12px;padding:12px 20px;margin:2px 8px;cursor:pointer;transition:all .3s ease;color:#bfdbfe;text-decoration:none;border:none;background:none;width:calc(100% - 16px);text-align:left;font-size:.9rem;border-radius:0 8px 8px 0;white-space:nowrap;overflow:hidden}.nav-item-collapsed{padding:12px 8px!important;margin:2px 4px!important;justify-content:center!important;width:calc(100% - 8px)!important;border-radius:8px!important;border-left:none!important}.nav-menu-fixed .nav-item:hover{background:rgba(255,255,255,.12);border-left-color:#60a5fa;transform:translateX(2px);color:white}.nav-item-collapsed:hover{transform:none!important;border-left-color:transparent!important}.nav-menu-fixed .nav-item.active{background:rgba(255,255,255,.18);border-left-color:#60a5fa;color:white;box-shadow:0 2px 10px rgba(96,165,250,.3);font-weight:600}.nav-item-collapsed.active{border-left-color:transparent!important;border-radius:8px!important}.nav-menu-fixed .nav-icon{width:18px;height:18px;flex-shrink:0;font-size:1rem;display:flex;align-items:center;justify-content:center}.nav-label{transition:opacity .3s ease}.logout-btn-collapsed{justify-content:center!important;padding:12px 8px!important}.sidebar-collapsed .logout-btn,.sidebar-collapsed .nav-item{position:relative}.sidebar-collapsed .logout-btn:hover:after,.sidebar-collapsed .nav-item:hover:after{left:100%;background:rgba(0,0,0,.8);z-index:1000;margin-left:8px;animation:fadeInTooltip .3s ease forwards}@keyframes fadeInTooltip{to{opacity:1}}@media (max-width:768px){.sidebar{width:260px}.sidebar-collapsed{width:70px}.sidebar-header-with-toggle{padding:12px 16px}.sidebar-collapsed .sidebar-header-with-toggle{padding:12px 8px}}@media (max-width:480px){.sidebar{width:240px}.sidebar-collapsed{width:60px}.logo-text p{font-size:.75rem}.user-details .user-name{font-size:.85rem}}:root{--badge-admin:#e74c3c;--badge-supervisor:#f39c12;--badge-auditor:#3498db;--badge-user:#95a5a6}.sidebar-quick-actions{padding:1rem;margin-top:auto;border-top:1px solid rgba(255,255,255,.1)}.quick-action-btn{width:100%;padding:.75rem;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:8px;color:white;display:flex;align-items:center;gap:.5rem;cursor:pointer;transition:all .3s ease}.quick-action-btn:hover{background:rgba(255,255,255,.2);transform:translateY(-2px)}.nav-badge{background:#e74c3c;color:white;font-size:.75rem;padding:.125rem .5rem;border-radius:12px;margin-left:auto;min-width:20px;text-align:center}.badge-supervisor{background:linear-gradient(135deg,var(--badge-supervisor),#e67e22);color:white;box-shadow:0 2px 8px rgba(243,156,18,.3)}.badge-auditor{background:linear-gradient(135deg,var(--badge-auditor),#2980b9);color:white;box-shadow:0 2px 8px rgba(52,152,219,.3)}.header-title-section{display:flex;flex-direction:column;gap:.25rem}.header-breadcrumb{font-size:.875rem;color:#666}.header-notifications{position:relative}.notification-btn{position:relative;background:none;border:none;font-size:1.5rem;cursor:pointer;padding:.5rem;border-radius:50%;transition:background .3s ease}.notification-btn:hover{background:#f5f5f5}.notification-badge{position:absolute;top:0;right:0;background:#e74c3c;color:white;font-size:.75rem;padding:.125rem .375rem;border-radius:12px;min-width:18px;text-align:center}.roles-container{max-width:1400px;margin:0 auto;background:transparent;overflow-x:hidden}.roles-info-content{padding:16px;display:flex;gap:12px}.roles-info-text h4{margin:0 0 8px;font-size:14px;font-weight:600;color:#1f2937}.roles-info-text p{margin:0;font-size:12px;color:#6b7280;line-height:1.4}.roles-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));grid-gap:16px;gap:16px;margin-top:32px}.roles-info-card{background:white;border-radius:8px;border:1px solid #e5e7eb;overflow:hidden}.roles-info-card.security{border-left:4px solid #10b981}.roles-info-card.warning{border-left:4px solid #f59e0b}.roles-info-card.success{border-left:4px solid #3b82f6}.roles-header{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem;background:linear-gradient(135deg,#ffffff,#f8faff);padding:2rem;border-radius:20px;box-shadow:0 10px 40px rgba(30,58,138,.12);border:1px solid #e0e7ff;position:relative;overflow:hidden}.roles-header:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#3b82f6,#8b5cf6,#06b6d4)}@media (min-width:640px){.roles-header{flex-direction:row;justify-content:space-between;align-items:center}}.roles-title h2{font-size:2.5rem;font-weight:900;background:linear-gradient(135deg,#1e40af,#3b82f6,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 .5rem;letter-spacing:-.025em}.roles-title p{color:#64748b;font-size:1.125rem;margin:0;font-weight:500}.header-buttons-group{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.roles-tabs{background:linear-gradient(135deg,#ffffff,#f8faff);border-radius:16px;padding:.75rem;margin-bottom:2rem;box-shadow:0 6px 30px rgba(30,58,138,.1);border:1px solid #e0e7ff}.roles-tabs-nav{display:flex;gap:.5rem;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.roles-tabs-nav::-webkit-scrollbar{display:none}.roles-tab{padding:1rem 2rem;border-radius:12px;font-weight:700;font-size:.875rem;color:#64748b;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);white-space:nowrap;background:none;border:none;position:relative;text-transform:uppercase;letter-spacing:.5px}.roles-tab:hover{color:#1e40af;transform:translateY(-2px)}.roles-tab.active{background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:white;box-shadow:0 6px 20px rgba(59,130,246,.4);transform:translateY(-2px)}.roles-list-container{background:linear-gradient(135deg,#ffffff,#f8faff);border-radius:20px;box-shadow:0 10px 40px rgba(30,58,138,.12);border:1px solid #e0e7ff;overflow:hidden}.roles-list-header{padding:2.5rem 2.5rem 1.5rem;background:linear-gradient(135deg,#f8faff,#f1f5f9);border-bottom:1px solid #e0e7ff;position:relative}.roles-list-header:before{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,#3b82f6,#8b5cf6)}.roles-list-header h3{font-size:1.75rem;font-weight:800;color:#1e293b;margin:0 0 .5rem;background:linear-gradient(135deg,#1e40af,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.roles-list-header p{font-size:1.125rem;color:#64748b;margin:0;font-weight:500}.roles-list-content{padding:.3rem}.roles-search-container{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem;background:linear-gradient(135deg,#f8faff,#f1f5f9);padding:2rem;border-radius:16px;border:1px solid #e0e7ff;box-shadow:0 4px 20px rgba(30,58,138,.08)}@media (min-width:640px){.roles-search-container{flex-direction:row;justify-content:space-between;align-items:center}}.roles-search-bar{position:relative;width:100%;max-width:32rem}.roles-search-results{font-size:.875rem;color:#64748b;font-weight:600;background:white;padding:.75rem 1.25rem;border-radius:12px;border:1px solid #e0e7ff;box-shadow:0 2px 8px rgba(0,0,0,.05)}.roles-grid{display:flex;flex-direction:column;gap:1.5rem}.role-card{background:linear-gradient(135deg,#ffffff,#f8faff);border:1px solid #e0e7ff;border-radius:20px;padding:2rem;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 4px 20px rgba(30,58,138,.08)}.role-card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(59,130,246,.03),rgba(139,92,246,.03));opacity:0;transition:opacity .3s ease}.role-card:hover{transform:translateY(-6px);box-shadow:0 25px 50px rgba(30,58,138,.18);border-color:#bfdbfe}.role-card:hover:before{opacity:1}.role-card-main{display:flex;align-items:center;justify-content:space-between;gap:2rem;position:relative;z-index:1}.role-card-info{flex:1 1;min-width:0}.role-card-title{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.role-card-title h3{font-size:1.5rem;font-weight:800;color:#1e293b;margin:0;letter-spacing:-.025em}.role-card-meta{display:flex;align-items:center;gap:1.5rem;font-size:.875rem;color:#64748b;flex-wrap:wrap;font-weight:600}.role-card-meta span{display:flex;align-items:center;gap:.5rem;background:rgba(148,163,184,.12);padding:.375rem 1rem;border-radius:8px;border:1px solid rgba(148,163,184,.2)}.role-card-actions{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;position:relative;z-index:1}.role-card-warning{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e0e7ff;position:relative;z-index:1}.role-card-warning-content{display:flex;align-items:center;gap:.75rem;font-size:.875rem;color:#2563eb;font-weight:600;background:rgba(37,99,235,.1);padding:1rem;border-radius:12px;border-left:4px solid #3b82f6}.system-lock{font-size:.75rem;background:linear-gradient(135deg,#f3f4f6,#e5e7eb);color:#6b7280;padding:.375rem 1rem;border-radius:8px;gap:.375rem;border:1px solid #d1d5db}.btn-roles-primary,.system-lock{display:inline-flex;align-items:center;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.btn-roles-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:white;border:none;padding:.875rem 1.75rem;border-radius:12px;font-size:.875rem;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 6px 20px rgba(59,130,246,.35);justify-content:center;gap:.5rem;cursor:pointer;position:relative;overflow:hidden}.btn-roles-primary:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-3px);box-shadow:0 12px 30px rgba(59,130,246,.45)}.btn-roles-secondary{background:linear-gradient(135deg,#059669,#047857);color:white;border:none;padding:.875rem 1.75rem;border-radius:12px;font-weight:700;font-size:.875rem;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 6px 20px rgba(5,150,105,.35);display:inline-flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;text-transform:uppercase;letter-spacing:.5px}.btn-roles-secondary:hover:not(:disabled){background:linear-gradient(135deg,#047857,#065f46);transform:translateY(-3px);box-shadow:0 12px 30px rgba(5,150,105,.45)}.btn-roles-outline{border:2px solid #3b82f6;background:rgba(59,130,246,.08);color:#2563eb;padding:.75rem 1.5rem;border-radius:12px;font-weight:700;font-size:.875rem;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);text-transform:uppercase;letter-spacing:.5px}.btn-roles-outline:hover:not(:disabled){background:rgba(59,130,246,.18);transform:translateY(-2px);box-shadow:0 6px 20px rgba(59,130,246,.25);border-color:#2563eb}.btn-roles-danger{border:2px solid #dc2626;background:rgba(220,38,38,.08);color:#dc2626;padding:.75rem 1.5rem;border-radius:12px;font-weight:700;font-size:.875rem;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;text-transform:uppercase;letter-spacing:.5px}.btn-roles-danger:hover:not(:disabled){background:rgba(220,38,38,.18);border-color:#b91c1c;color:#b91c1c;transform:translateY(-2px);box-shadow:0 6px 20px rgba(220,38,38,.25)}.btn-roles-danger:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-roles-sm{padding:.625rem 1.25rem;font-size:.8rem;border-radius:10px}.permission-matrix-container{max-width:1200px;margin:0 auto;background:transparent}.permission-matrix-header{background:linear-gradient(135deg,#ffffff,#f8faff);border:1px solid #e0e7ff;border-radius:20px;padding:2rem;margin-bottom:2rem;box-shadow:0 8px 32px rgba(30,58,138,.12);position:relative;overflow:hidden}.permission-matrix-header:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#3b82f6,#8b5cf6,#06b6d4)}.permission-matrix-header-content{display:flex;justify-content:space-between;align-items:center;gap:2rem;flex-wrap:wrap}.permission-matrix-title h3{font-size:1.875rem;font-weight:800;color:#1e293b;margin:0 0 .5rem;background:linear-gradient(135deg,#1e40af,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.permission-matrix-subtitle{color:#64748b;font-size:1rem;font-weight:500;margin:0}.permission-matrix-stats{text-align:right}.matrix-modules-grid{display:grid;grid-gap:1.5rem;gap:1.5rem;grid-template-columns:1fr;width:100%}@media (min-width:1024px){.matrix-modules-grid{grid-template-columns:repeat(2,1fr)}}.matrix-module-card{background:linear-gradient(135deg,#ffffff,#f8faff);border:1px solid #e0e7ff;border-radius:16px;overflow:hidden;box-shadow:0 8px 32px rgba(30,58,138,.12);transition:all .3s cubic-bezier(.4,0,.2,1)}.matrix-module-card:hover{transform:translateY(-4px);box-shadow:0 16px 48px rgba(30,58,138,.18)}.matrix-module-header{padding:1.5rem;border-bottom:1px solid #e0e7ff;position:relative}.matrix-module-header.complete{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border-bottom-color:#86efac}.matrix-module-header.partial{background:linear-gradient(135deg,#fef3c7,#fde68a);border-bottom-color:#fbbf24}.matrix-module-header.none{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border-bottom-color:#d1d5db}.matrix-module-header-content{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.matrix-module-info{display:flex;align-items:center;gap:1rem;flex:1 1;min-width:0}.matrix-module-icon{font-size:1.25rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:10px;color:white;box-shadow:0 4px 15px rgba(59,130,246,.3);flex-shrink:0}.matrix-module-details h4{font-size:1.125rem;font-weight:700;color:#1e293b;margin:0 0 .25rem;display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.matrix-module-details p{font-size:.875rem;color:#64748b;margin:0;font-weight:500}.matrix-module-status{font-size:.7rem;padding:.25rem .75rem;border-radius:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.matrix-module-status.complete{background:linear-gradient(135deg,#10b981,#059669);color:white}.matrix-module-status.partial{background:linear-gradient(135deg,#f59e0b,#d97706);color:white}.matrix-module-controls{display:flex;flex-direction:column;gap:.5rem;flex-shrink:0;align-items:stretch;min-width:90px}.matrix-module-controls .btn-roles-outline{padding:.5rem .75rem;font-size:.75rem;border-radius:6px;width:100%;text-align:center}.matrix-module-content{padding:1.5rem}.matrix-permissions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));grid-gap:1rem;gap:1rem;width:100%}.matrix-permission-item{background:white;border:2px solid #e0e7ff;border-radius:12px;padding:1rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;display:flex;align-items:center;gap:.75rem}.matrix-permission-item:hover{border-color:#3b82f6;transform:translateY(-2px);box-shadow:0 8px 25px rgba(59,130,246,.15)}.matrix-permission-item.granted{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border-color:#10b981;box-shadow:0 4px 15px rgba(16,185,129,.2)}.matrix-permission-checkbox{width:20px;height:20px;border:2px solid #d1d5db;border-radius:6px;background:white;display:flex;align-items:center;justify-content:center;transition:all .3s ease;flex-shrink:0}.matrix-permission-checkbox.granted{background:linear-gradient(135deg,#10b981,#059669);border-color:#10b981;color:white}.matrix-permission-check{font-size:.75rem;font-weight:700}.matrix-permission-info{flex:1 1;min-width:0}.matrix-permission-name{font-size:.875rem;font-weight:600;color:#374151;margin-bottom:.125rem;word-wrap:break-word}.matrix-permission-item.granted .matrix-permission-name{color:#065f46;font-weight:700}.matrix-permission-code{font-size:.75rem;color:#9ca3af;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.roles-breadcrumb{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-top:2rem;padding:1.5rem;background:linear-gradient(135deg,#f8faff,#f1f5f9);border:1px solid #e0e7ff;border-radius:16px;box-shadow:0 4px 20px rgba(30,58,138,.08)}@media (max-width:1024px){.roles-container{padding:1.5rem}.matrix-modules-grid{grid-template-columns:1fr}.matrix-permissions-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}}@media (max-width:768px){.roles-container{padding:1rem}.roles-header{padding:1.5rem;flex-direction:column;text-align:center}.roles-title h2{font-size:2rem}.header-buttons-group{width:100%;justify-content:center}.role-card{padding:1.5rem}.role-card-main{flex-direction:column;align-items:flex-start;gap:1.5rem}.role-card-actions{width:100%;justify-content:flex-start}.matrix-module-header-content{flex-direction:column;align-items:stretch}.matrix-module-controls{flex-direction:row;align-items:center}.matrix-permissions-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.matrix-permission-item{padding:.75rem}.roles-breadcrumb{flex-direction:column;align-items:stretch}}@media (max-width:640px){.roles-breadcrumb{flex-direction:column;align-items:stretch}}@media (max-width:480px){.roles-container{padding:.75rem}.roles-header{padding:1rem}.roles-title h2{font-size:1.75rem}.role-card{padding:1rem}.matrix-permissions-grid{grid-template-columns:1fr}.matrix-permission-item{padding:.5rem}}.empty-state{text-align:center;padding:4rem 2rem;background:linear-gradient(135deg,#f8faff,#f1f5f9);border-radius:20px;border:2px dashed #cbd5e1;margin:2rem 0}.empty-state-icon{font-size:4rem;margin-bottom:1.5rem;display:block;filter:grayscale(.3)}.empty-state h3{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0 0 .75rem}.empty-state p{color:#64748b;margin:0;font-size:1.1rem;font-weight:500}.role-card:focus-within{outline:3px solid #93c5fd;outline-offset:2px}.btn-roles-danger:focus,.btn-roles-outline:focus,.btn-roles-primary:focus,.btn-roles-secondary:focus,.matrix-permission-item:focus{outline:3px solid rgba(59,130,246,.5);outline-offset:2px}body,html{max-width:100vw}*{box-sizing:border-box}.matrix-module-card,.matrix-modules-grid,.roles-container,.roles-header,.roles-list-container{max-width:100%;overflow-x:hidden}.roles-loading{flex-direction:column;padding:2rem}.roles-loading,.roles-loading-header{display:flex;gap:2rem}.roles-loading-item{height:4rem;background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0 50%,#f1f5f9 75%);background-size:200% 100%;border-radius:16px;animation:shimmer 2s infinite}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.matrix-saving,.role-form-saving{pointer-events:none;opacity:.7}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.role-card{animation:fadeInUp .5s ease-out}.role-card:nth-child(2){animation-delay:.1s}.role-card:nth-child(3){animation-delay:.2s}.role-card:nth-child(4){animation-delay:.3s}.matrix-module-card{animation:fadeInUp .6s ease-out}.matrix-module-card:nth-child(2){animation-delay:.15s}.matrix-module-card:nth-child(3){animation-delay:.3s}.matrix-module-card:nth-child(4){animation-delay:.45s}.access-denied-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:#f8f9fa}.access-denied-content{text-align:center;padding:3rem;background:white;border-radius:12px;box-shadow:0 4px 6px rgba(0,0,0,.1);max-width:400px}.access-denied-icon{font-size:4rem;margin-bottom:1rem}.access-denied-content h2{color:#333;margin-bottom:1rem}.access-denied-content p{color:#666;margin-bottom:2rem}@media (prefers-reduced-motion:reduce){.matrix-module-card,.role-card{animation:none}*{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}@media (prefers-contrast:high){.matrix-module-card,.role-card,.roles-header,.roles-list-container{border-width:2px;border-color:#000}.btn-roles-primary,.btn-roles-secondary{border:2px solid #000}}.role-form-container{max-width:900px;margin:0 auto;background:linear-gradient(135deg,#ffffff,#f8faff);border-radius:20px;box-shadow:0 10px 40px rgba(30,58,138,.12);border:1px solid #e0e7ff;overflow:hidden}.role-form-section{border-bottom:1px solid #e0e7ff}.role-form-section:last-child{border-bottom:none}.role-form-section-content{padding:2.5rem}.role-form-section-content h4{font-size:1.5rem;font-weight:800;color:#1e293b;margin:0 0 1.5rem;background:linear-gradient(135deg,#1e40af,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.role-form-group{margin-bottom:1.5rem}.role-form-label{display:block;font-size:.875rem;font-weight:700;color:#374151;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.5px}.role-form-input{width:100%;padding:1rem 1.25rem;border:2px solid #d1d5db;border-radius:12px;font-size:1rem;transition:all .3s ease;background:white;font-weight:500}.role-form-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 4px rgba(59,130,246,.1);transform:translateY(-1px)}.role-form-input.error{border-color:#dc2626;box-shadow:0 0 0 4px rgba(220,38,38,.1)}.role-form-error{color:#dc2626;font-size:.875rem;margin-top:.5rem;font-weight:600}.role-permissions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.role-permissions-grid{display:grid;grid-gap:2rem;gap:2rem}.role-module-card{background:linear-gradient(135deg,#f8faff,#f1f5f9);border:1px solid #e0e7ff;border-radius:16px;padding:1.5rem;transition:all .3s ease}.role-module-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(30,58,138,.12)}.role-module-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #e0e7ff}.role-module-info{display:flex;align-items:center;gap:1rem}.role-module-icon{font-size:1.5rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:12px;color:white;box-shadow:0 4px 15px rgba(59,130,246,.3)}.role-module-text h5{font-size:1.125rem;font-weight:700;color:#1e293b;margin:0 0 .25rem}.role-module-text p{font-size:.875rem;color:#64748b;margin:0;font-weight:500}.role-module-controls{display:flex;gap:.75rem}.role-actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:1rem;gap:1rem;padding:.5rem 0}@media (min-width:768px){.role-actions-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}.role-action-item{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:white;border:2px solid #e0e7ff;border-radius:12px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.role-action-item:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(59,130,246,.05),rgba(139,92,246,.05));opacity:0;transition:opacity .3s ease}.role-action-item:hover{border-color:#3b82f6;transform:translateY(-2px);box-shadow:0 8px 25px rgba(59,130,246,.15)}.role-action-item:hover:before{opacity:1}.role-action-item:has(.role-action-checkbox:checked){background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-color:#3b82f6;box-shadow:0 4px 15px rgba(59,130,246,.2)}.role-action-checkbox{width:20px;height:20px;border:2px solid #d1d5db;border-radius:6px;background:white;cursor:pointer;position:relative;transition:all .3s ease;appearance:none;-webkit-appearance:none;-moz-appearance:none;flex-shrink:0}.role-action-checkbox:checked{background:linear-gradient(135deg,#3b82f6,#2563eb);border-color:#3b82f6;transform:scale(1.1)}.role-action-checkbox:checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:white;font-size:.75rem;font-weight:700}.role-action-checkbox:focus{outline:none;box-shadow:0 0 0 3px rgba(59,130,246,.2)}.role-action-label{font-size:.875rem;font-weight:600;color:#374151;flex:1 1;cursor:pointer;position:relative;z-index:1}.role-action-item:has(.role-action-checkbox:checked) .role-action-label{color:#1e40af;font-weight:700}.role-action-name{font-size:.875rem;font-weight:600;color:#374151;margin-bottom:.125rem}.role-action-code{font-size:.75rem;color:#9ca3af;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.role-action-item:has(.role-action-checkbox:checked) .role-action-name{color:#1e40af;font-weight:700}.role-action-item:has(.role-action-checkbox:checked) .role-action-code{color:#3b82f6}.role-permissions-empty{text-align:center;padding:3rem;background:linear-gradient(135deg,#f8faff,#f1f5f9);border:2px dashed #cbd5e1;border-radius:16px}.role-permissions-empty-icon{font-size:3rem;margin-bottom:1rem;display:block}.role-permissions-empty p{color:#64748b;font-size:1rem;font-weight:500;margin:.5rem 0}.role-quick-actions{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #0ea5e9;border-radius:16px;padding:1.5rem;margin-top:2rem}.role-quick-actions-header{margin-bottom:1rem}.role-quick-actions-header h5{font-size:1rem;font-weight:700;color:#0c4a6e;margin:0;text-transform:uppercase;letter-spacing:.5px}.role-quick-actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));grid-gap:.75rem;gap:.75rem}@media (max-width:640px){.role-quick-actions-grid{grid-template-columns:1fr 1fr}}.role-module-header.complete{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border-bottom-color:#86efac}.role-module-header.partial{background:linear-gradient(135deg,#fef3c7,#fde68a);border-bottom-color:#fbbf24}.role-module-header.none{background:linear-gradient(135deg,#f9fafb,#f3f4f6);border-bottom-color:#e5e7eb}.role-form-actions{display:flex;justify-content:flex-end;gap:1rem;padding:2rem 2.5rem;background:linear-gradient(135deg,#f8faff,#f1f5f9);border-top:1px solid #e0e7ff}.role-form-error-alert{background:linear-gradient(135deg,#fef2f2,#fee2e2);border:1px solid #fecaca;border-radius:12px;padding:1rem;margin-bottom:1.5rem}.role-form-error-content{display:flex;align-items:center;gap:.75rem}.role-form-error-icon{font-size:1.25rem;flex-shrink:0}.role-form-error-text{color:#dc2626;font-weight:600;margin:0}.role-form-tip{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1px solid #bfdbfe;border-radius:12px;padding:1.5rem;margin-top:1rem}.role-form-tip-content{display:flex;gap:1rem}.role-form-tip-icon{font-size:1.5rem;flex-shrink:0}.role-form-tip-text h5{font-size:.875rem;font-weight:700;color:#1e40af;margin:0 0 .5rem;text-transform:uppercase;letter-spacing:.5px}.role-form-tip-text ul{margin:0;padding:0;list-style:none}.role-form-tip-text li{color:#1e40af;font-size:.875rem;font-weight:500;margin-bottom:.25rem}@media (max-width:768px){.role-module-header{flex-direction:column;align-items:flex-start;gap:1rem}.role-module-controls{width:100%;justify-content:flex-end}.role-actions-grid{grid-template-columns:1fr;gap:.75rem}.role-quick-actions-grid{grid-template-columns:1fr;gap:.5rem}.role-form-actions{flex-direction:column}}@media (max-width:480px){.role-form-actions,.role-form-section-content{padding:1.5rem}}.permission-legend{background:linear-gradient(135deg,#f8faff,#f1f5f9);border:1px solid #e0e7ff;border-radius:16px;padding:2rem;margin-top:2rem;box-shadow:0 4px 20px rgba(30,58,138,.08)}.permission-legend-content h5{font-size:1rem;font-weight:700;color:#1e293b;margin:0 0 1rem;text-transform:uppercase;letter-spacing:.5px}.permission-legend-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:1rem;gap:1rem}.permission-legend-item{display:flex;align-items:center;gap:.75rem;font-size:.875rem;font-weight:500;color:#64748b;padding:.5rem;border-radius:8px;transition:all .3s ease}.permission-legend-item:hover{background:rgba(59,130,246,.05);color:#1e40af}.permission-legend-item:first-child{color:#065f46}.permission-legend-item:first-child:hover{background:rgba(16,185,129,.1);color:#065f46}.permission-legend-item:nth-child(2){color:#64748b}.permission-legend-item:nth-child(2):hover{background:rgba(148,163,184,.1);color:#475569}.permission-legend-item:nth-child(3){color:#92400e}.permission-legend-item:nth-child(3):hover{background:rgba(245,158,11,.1);color:#92400e}.permission-legend-item:nth-child(4){color:#065f46}.permission-legend-item:nth-child(4):hover{background:rgba(16,185,129,.1);color:#065f46}.permission-legend .matrix-permission-checkbox{width:20px;height:20px;border:2px solid #d1d5db;border-radius:6px;background:white;display:flex;align-items:center;justify-content:center;flex-shrink:0}.permission-legend .matrix-permission-checkbox.granted{background:linear-gradient(135deg,#10b981,#059669);border-color:#10b981;color:white}.permission-legend .matrix-permission-check{font-size:.75rem;font-weight:700}.permission-legend .matrix-permission-badge{width:12px;height:12px;background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:50%;box-shadow:0 2px 8px rgba(245,158,11,.4);flex-shrink:0}.permission-legend .complete-module-icon{color:#16a34a;font-size:1.125rem;flex-shrink:0}@media (max-width:768px){.permission-legend-grid{grid-template-columns:1fr;gap:.75rem}.permission-legend{padding:1.5rem;margin-top:1.5rem}.permission-legend-item{padding:.75rem;font-size:.8rem}}@media (max-width:480px){.permission-legend{padding:1rem;margin-top:1rem}.permission-legend-content h5{font-size:.9rem}.permission-legend-item{gap:.5rem;padding:.5rem}}.pending-changes-alert{position:-webkit-sticky;position:sticky;top:1rem;z-index:50;margin-bottom:2rem}.pending-changes-content{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;border-radius:16px;box-shadow:0 8px 32px rgba(245,158,11,.25);overflow:hidden;animation:slideInDown .3s ease-out}@keyframes slideInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.pending-changes-inner{padding:1rem 1.5rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.pending-changes-message{display:flex;align-items:center;gap:.75rem}.pending-changes-icon{font-size:1.25rem;animation:pulse 2s infinite}.pending-changes-text{font-weight:700;color:#92400e;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.pending-changes-actions{display:flex;gap:.75rem}.no-edit-info{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1px solid #bfdbfe;border-radius:16px;padding:1.5rem;margin-top:2rem}.no-edit-info-content{display:flex;align-items:center;gap:1rem}.no-edit-info-icon{font-size:1.5rem;flex-shrink:0;color:#2563eb}.no-edit-info-text{color:#1e40af;font-weight:600;margin:0}.permission-matrix-progress{font-size:1.25rem;font-weight:700;color:#1e40af;margin-bottom:.5rem}.permission-matrix-progress-bar{width:200px;height:8px;background:#e0e7ff;border-radius:4px;overflow:hidden;box-shadow:inset 0 2px 4px rgba(0,0,0,.1)}.permission-matrix-progress-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#8b5cf6);border-radius:4px;transition:width .5s ease;box-shadow:0 2px 8px rgba(59,130,246,.3)}.legend-module-complete{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:1px solid #86efac;color:#065f46}.legend-module-partial{background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #fbbf24;color:#92400e}.legend-module-none{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border:1px solid #d1d5db;color:#6b7280}.modal-overlay{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:1rem}.modal-backdrop{position:fixed;inset:0;background-color:rgba(0,0,0,.5);transition:opacity .3s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-container{position:relative;width:100%;max-width:32rem;animation:modalSlideIn .3s ease}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-content{background-color:white;border-radius:.75rem;box-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 10px 10px -5px rgba(0,0,0,.04);overflow:hidden}.modal-header{padding:1.5rem;gap:1rem;border-bottom:1px solid #e5e7eb}.modal-header,.modal-icon{display:flex;align-items:center}.modal-icon{width:3rem;height:3rem;border-radius:50%;justify-content:center;flex-shrink:0;font-size:1.5rem}.modal-title{font-size:1.125rem;font-weight:600;margin:0;line-height:1.25}.modal-body{padding:1.5rem}.modal-message{color:#4b5563;margin:0;line-height:1.5}.modal-message p{margin:0 0 .5rem}.modal-message p:last-child{margin-bottom:0}.modal-message strong{color:#1f2937;font-weight:600}.modal-reason-input{margin-top:1rem}.reason-textarea{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;resize:none;transition:all .2s ease;font-family:inherit;line-height:1.5}.reason-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px rgba(59,130,246,.1)}.reason-textarea:disabled{background-color:#f3f4f6;cursor:not-allowed;opacity:.6}.modal-footer{padding:1rem 1.5rem;background-color:#f9fafb;display:flex;gap:.75rem;justify-content:flex-end;border-top:1px solid #e5e7eb}.modal-button{padding:.625rem 1.25rem;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;border:none;outline:none;display:inline-flex;align-items:center;justify-content:center;min-width:5rem}.modal-button:focus-visible{outline:2px solid transparent;outline-offset:2px}.modal-button:disabled{opacity:.5;cursor:not-allowed}.modal-button-cancel{background-color:white;color:#374151;border:1px solid #d1d5db}.modal-button-cancel:hover:not(:disabled){background-color:#f9fafb;border-color:#9ca3af}.modal-button-cancel:focus-visible{box-shadow:0 0 0 3px rgba(209,213,219,.5)}.modal-button-confirm{color:white}.bg-red-100{background-color:#fee2e2}.bg-yellow-100{background-color:#fef3c7}.bg-blue-100{background-color:#dbeafe}.text-red-900{color:#7f1d1d}.text-yellow-900{color:#78350f}.text-gray-900{color:#111827}.text-gray-600{color:#4b5563}.text-sm{font-size:.875rem;line-height:1.25rem}.bg-red-600{background-color:#dc2626}.bg-red-600:hover:not(:disabled){background-color:#b91c1c}.bg-red-600:focus-visible{box-shadow:0 0 0 3px rgba(220,38,38,.3)}.bg-yellow-600{background-color:#d97706}.bg-yellow-600:hover:not(:disabled){background-color:#b45309}.bg-yellow-600:focus-visible{box-shadow:0 0 0 3px rgba(217,119,6,.3)}.bg-blue-600{background-color:#2563eb}.bg-blue-600:hover:not(:disabled){background-color:#1d4ed8}.bg-blue-600:focus-visible{box-shadow:0 0 0 3px rgba(37,99,235,.3)}@media (max-width:640px){.modal-overlay{padding:0}.modal-container{max-width:100%;height:100%;display:flex;align-items:flex-end}.modal-content{border-radius:0;border-top-left-radius:1rem;border-top-right-radius:1rem;width:100%;animation:modalSlideUp .3s ease}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.modal-body,.modal-header{padding:1.25rem}.modal-footer{padding:1rem 1.25rem;flex-direction:column-reverse;gap:.5rem}.modal-button{width:100%}}@media (prefers-color-scheme:dark){.modal-content{background-color:#1f2937;color:#f3f4f6}.modal-header{border-bottom-color:#374151}.modal-footer{background-color:#111827;border-top-color:#374151}.modal-message{color:#d1d5db}.modal-message strong{color:#f3f4f6}.reason-textarea{background-color:#1f2937;border-color:#374151;color:#f3f4f6}.reason-textarea:focus{border-color:#3b82f6}.modal-button-cancel{background-color:#374151;color:#f3f4f6;border-color:#4b5563}.modal-button-cancel:hover:not(:disabled){background-color:#4b5563;border-color:#6b7280}}.main-content{flex:1 1;transition:margin-left .3s ease;margin-left:0;overflow:hidden}.dashboard-container:has(.sidebar:not(.sidebar-collapsed)) .main-content{margin-left:0}.main-content-expanded{margin-left:0}.sidebar{position:fixed;left:0;top:0;z-index:1000;transition:width .3s ease,transform .3s ease}.dashboard-container{padding-left:288px;transition:padding-left .3s ease}.dashboard-container:has(.sidebar-collapsed){padding-left:80px}.hamburger-icon span{transform-origin:center}.hamburger-collapsed span:first-child{transform:rotate(45deg) translate(5px,5px)}.hamburger-collapsed span:nth-child(2){opacity:0;transform:scale(0)}.hamburger-collapsed span:nth-child(3){transform:rotate(-45deg) translate(7px,-6px)}.sidebar-collapsed .logout-btn:hover:after,.sidebar-collapsed .nav-item:hover:after{content:attr(title);position:absolute;left:calc(100% + 8px);top:50%;transform:translateY(-50%);background:rgba(0,0,0,.9);color:white;padding:8px 12px;border-radius:6px;font-size:.8rem;white-space:nowrap;z-index:2000;pointer-events:none;opacity:0;animation:tooltipFadeIn .2s ease-in-out forwards;box-shadow:0 4px 12px rgba(0,0,0,.3)}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateY(-50%) translateX(-5px)}to{opacity:1;transform:translateY(-50%) translateX(0)}}body,html{overflow-x:hidden}.dashboard-container{overflow-x:hidden;max-width:100vw}@media (max-width:1024px){.dashboard-container{padding-left:260px}.dashboard-container:has(.sidebar-collapsed){padding-left:70px}.sidebar{width:260px}.sidebar-collapsed{width:70px}}@media (max-width:768px){.dashboard-container{padding-left:0}.sidebar{transform:translateX(-100%);box-shadow:none}.sidebar:not(.sidebar-collapsed){transform:translateX(0);box-shadow:4px 0 20px rgba(0,0,0,.3)}.sidebar-collapsed{transform:translateX(-100%)}.dashboard-container:has(.sidebar:not(.sidebar-collapsed)):before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:999}}@media (max-width:480px){.sidebar{width:280px}.logo-text h2{font-size:1.1rem}.logo-text p{font-size:.75rem}}.nav-item{position:relative;overflow:visible}.sidebar-loading{display:flex;justify-content:center;align-items:center;height:100px;color:#bfdbfe}.sidebar-loading .spinner{width:20px;height:20px;border:2px solid transparent;border-top-color:#bfdbfe;border-radius:50%;animation:spin 1s linear infinite}.nav-menu-fixed{scroll-behavior:smooth}.nav-item.active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(135deg,#60a5fa,#3b82f6);border-radius:0 2px 2px 0;animation:activeSlideIn .3s ease-out}@keyframes activeSlideIn{0%{width:0;opacity:0}to{width:4px;opacity:1}}.nav-item:hover{transform:translateX(2px);background:rgba(255,255,255,.12)}.nav-item-collapsed:hover{transform:scale(1.05);background:rgba(255,255,255,.15)}.sidebar *{transition:all .3s ease}.hamburger-btn:focus,.logout-btn:focus,.nav-item:focus{outline:2px solid #60a5fa;outline-offset:2px}.sidebar-error{padding:1rem;text-align:center;color:#fca5a5;font-size:.8rem}.sidebar-retry-btn{background:rgba(239,68,68,.2);border:1px solid #fca5a5;color:#fca5a5;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.8rem;margin-top:.5rem;transition:all .3s ease}.sidebar-retry-btn:hover{background:rgba(239,68,68,.3);transform:translateY(-1px)}.pagination-container{display:flex;flex-direction:column;gap:1rem;align-items:center;margin:2rem 0;padding:1.5rem;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0}@media (min-width:640px){.pagination-container{flex-direction:row;justify-content:space-between}}.pagination-info{font-size:.875rem;color:#475569;font-weight:500}.pagination-info .font-medium{font-weight:600;color:#1e293b}.pagination-controls{gap:2px;border-radius:8px;border:1px solid #d1d5db;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.1)}.pagination-btn,.pagination-controls{display:flex;align-items:center;background:white}.pagination-btn{padding:.75rem 1rem;font-size:.875rem;font-weight:500;border:none;color:#6b7280;cursor:pointer;transition:all .2s ease;gap:.5rem;min-width:44px;justify-content:center}.pagination-btn:hover:not(:disabled){background:#f9fafb;color:#374151}.pagination-btn:disabled{opacity:.5;cursor:not-allowed;background:#f3f4f6}.pagination-btn.prev{border-radius:6px 0 0 6px;border-right:1px solid #e5e7eb}.pagination-btn.next{border-radius:0 6px 6px 0;border-left:1px solid #e5e7eb}.pagination-current{font-weight:600;background:#3b82f6;color:white;border:none}.pagination-current,.pagination-number{padding:.75rem 1rem;font-size:.875rem;min-width:44px;display:flex;align-items:center;justify-content:center}.pagination-number{font-weight:500;background:white;color:#374151;cursor:pointer;transition:all .2s ease;border:1px solid #e5e7eb;border-top:none;border-bottom:none}.pagination-number:hover{background:#eff6ff;color:#2563eb}.pagination-number.active{background:#2563eb;color:white;z-index:10}.pagination-dots{padding:.75rem 1rem;font-size:.875rem;font-weight:500;color:#6b7280;background:white;min-width:44px;border-left:1px solid #e5e7eb;border-right:1px solid #e5e7eb}.pagination-dots,.pagination-simple{display:flex;align-items:center;justify-content:center}.pagination-simple{gap:1rem;margin:2rem 0;padding:1rem;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0}.pagination-simple .pagination-info{font-size:.875rem;color:#475569;text-align:center;margin-bottom:1rem}.pagination-simple .pagination-controls{background:white;border-radius:8px;border:1px solid #d1d5db;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.1);display:flex}.pagination-simple .pagination-btn{padding:.75rem 1.25rem;font-size:.875rem;font-weight:500;border:none;background:white;color:#6b7280;cursor:pointer;transition:all .2s ease}.pagination-simple .pagination-btn:hover:not(:disabled){background:#f9fafb;color:#374151}.pagination-simple .pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-simple .pagination-current{padding:.75rem 1.25rem;font-size:.875rem;font-weight:600;background:#3b82f6;color:white;border-left:1px solid #d1d5db;border-right:1px solid #d1d5db}@media (max-width:640px){.pagination-container{padding:1rem;margin:1rem 0}.pagination-controls{gap:1px}.pagination-btn,.pagination-current,.pagination-number{padding:.5rem .75rem;font-size:.8rem;min-width:36px}.pagination-info{font-size:.8rem;text-align:center}}.pagination-loading{opacity:.6;pointer-events:none}.pagination-loading .pagination-btn,.pagination-loading .pagination-current{animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.pagination-btn:focus,.pagination-number:focus{outline:2px solid #3b82f6;outline-offset:2px}.pagination-empty{text-align:center;padding:1rem;color:#6b7280;font-size:.875rem;font-style:italic}.dashboard-page{padding:1.5rem;background:#f8fafc;min-height:100vh}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:1rem;color:#6b7280}.dashboard-welcome{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding:2rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:white;box-shadow:0 4px 6px -1px rgba(0,0,0,.1)}.welcome-content h1{margin:0 0 .5rem;font-size:2rem;font-weight:700}.welcome-content p{margin:0;opacity:.9;font-size:1rem}.welcome-date{font-size:.875rem;opacity:.8;font-weight:500}.dashboard-recent-section{margin-top:2rem}@media (max-width:768px){.dashboard-page{padding:1rem}.dashboard-welcome{flex-direction:column;gap:1rem;text-align:center}.welcome-content h1{font-size:1.5rem}}