.galaxy-login-container{position:relative;width:100vw;height:100vh;overflow:hidden;background:#0a0a0f;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif}.galaxy-background{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1}.galaxy-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(ellipse at center,transparent 0%,rgba(10,10,20,.3) 100%);z-index:2;pointer-events:none}.galaxy-content{position:relative;z-index:10;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:2rem;gap:2rem}.galaxy-header{text-align:center;animation:fadeInDown 1s ease-out}.logo-container{position:relative;width:120px;height:120px;margin:0 auto 1.5rem}.logo-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:150px;height:150px;background:radial-gradient(circle,rgba(96,165,250,.4),transparent 70%);filter:blur(30px);animation:pulse 3s ease-in-out infinite}.logo-svg{position:relative;z-index:2;width:100%;height:100%;filter:drop-shadow(0 0 20px rgba(96,165,250,.5));animation:float 6s ease-in-out infinite}.brand-name{font-size:4rem;font-weight:800;margin:0;background:linear-gradient(135deg,#60a5fa,#a78bfa,#ec4899);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;text-shadow:0 0 40px rgba(96,165,250,.3);letter-spacing:-.02em}.brand-e{font-style:italic}.brand-subtitle{font-size:1.125rem;color:#94a3b8;margin-top:.5rem;font-weight:300;letter-spacing:.05em;text-transform:uppercase}.login-card-galaxy{position:relative;width:100%;max-width:480px;background:#0f172ab3;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:24px;border:1px solid rgba(148,163,184,.15);box-shadow:0 20px 60px #00000080,0 0 80px #60a5fa33,inset 0 1px #ffffff0d;overflow:hidden;animation:fadeInUp 1s ease-out .2s both,cardFloat 4s ease-in-out infinite}.card-glow{position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:conic-gradient(from 0deg at 50% 50%,transparent 0deg,rgba(96,165,250,.2) 60deg,transparent 120deg,transparent 240deg,rgba(167,139,250,.2) 300deg,transparent 360deg);animation:rotate 8s linear infinite;opacity:.5}.card-content{position:relative;z-index:1;padding:3rem 2.5rem}.welcome-section{text-align:center;margin-bottom:2rem}.welcome-title{font-size:2rem;font-weight:700;color:#f1f5f9;margin:0 0 .5rem;background:linear-gradient(135deg,#f1f5f9,#cbd5e1);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.welcome-subtitle{font-size:.9375rem;color:#94a3b8;margin:0;font-weight:400}.galaxy-login-btn{position:relative;width:100%;padding:1rem 2rem;background:transparent;border:none;border-radius:12px;cursor:pointer;overflow:hidden;transition:transform .2s ease;font-size:1rem;font-weight:600}.galaxy-login-btn:hover{transform:translateY(-2px)}.galaxy-login-btn:active{transform:translateY(0)}.galaxy-login-btn:disabled{cursor:not-allowed;opacity:.7}.btn-bg{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#3b82f6,#8b5cf6,#ec4899);z-index:-1}.btn-content{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;gap:.75rem;color:#fff}.btn-icon{display:flex;align-items:center;width:24px;height:24px}.btn-icon svg{width:100%;height:100%}.btn-shine{position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shine 3s ease-in-out infinite}.spinner-galaxy{width:24px;height:24px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.security-section{margin-top:2rem}.security-divider{position:relative;text-align:center;margin:2rem 0 1.5rem}.security-divider:before,.security-divider:after{content:"";position:absolute;top:50%;width:30%;height:1px;background:linear-gradient(to right,transparent,rgba(148,163,184,.3),transparent)}.security-divider:before{left:0}.security-divider:after{right:0}.security-divider span{position:relative;padding:0 1rem;font-size:.75rem;color:#64748b;text-transform:uppercase;letter-spacing:.1em;font-weight:500}.security-features{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.security-badge{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem .5rem;background:#0f172a80;border-radius:12px;border:1px solid rgba(148,163,184,.1);transition:all .3s ease}.security-badge:hover{background:#1e293b99;border-color:#60a5fa4d;transform:translateY(-2px)}.security-badge svg{width:24px;height:24px;color:#60a5fa}.security-badge span{font-size:.75rem;color:#94a3b8;font-weight:500}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:900px;width:100%;animation:fadeInUp 1s ease-out .4s both}.feature-card{background:#0f172a99;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(148,163,184,.1);border-radius:16px;padding:2rem 1.5rem;text-align:center;transition:all .3s ease}.feature-card:hover{background:#1e293bb3;border-color:#60a5fa4d;transform:translateY(-4px)}.feature-icon-wrapper{width:48px;height:48px;margin:0 auto 1rem;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#60a5fa33,#a78bfa33);border-radius:12px;color:#60a5fa}.feature-icon-wrapper svg{width:24px;height:24px}.feature-card h3{font-size:1.125rem;font-weight:600;color:#f1f5f9;margin:0 0 .5rem}.feature-card p{font-size:.875rem;color:#94a3b8;margin:0}.galaxy-footer{text-align:center;animation:fadeIn 1s ease-out .6s both}.galaxy-footer p{font-size:.875rem;color:#64748b;margin:0 0 .75rem}.footer-links{display:flex;align-items:center;justify-content:center;gap:.75rem;font-size:.8125rem}.footer-links a{color:#94a3b8;text-decoration:none;transition:color .3s ease}.footer-links a:hover{color:#60a5fa}.footer-links span{color:#475569}.floating-elements{position:absolute;top:0;left:0;width:100%;height:100%;z-index:3;pointer-events:none}.float-orb{position:absolute;border-radius:50%;filter:blur(60px);opacity:.3}.float-orb.orb-1{width:400px;height:400px;top:-200px;left:-200px;background:radial-gradient(circle,rgba(96,165,250,.4),transparent);animation:float 8s ease-in-out infinite}.float-orb.orb-2{width:300px;height:300px;bottom:-150px;right:-150px;background:radial-gradient(circle,rgba(167,139,250,.4),transparent);animation:float 10s ease-in-out infinite reverse}.float-orb.orb-3{width:350px;height:350px;top:50%;left:50%;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(236,72,153,.3),transparent);animation:pulse 6s ease-in-out infinite}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@keyframes pulse{0%,to{transform:translate(-50%,-50%) scale(1);opacity:.3}50%{transform:translate(-50%,-50%) scale(1.1);opacity:.5}}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes shine{0%{left:-100%}50%,to{left:100%}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes cardFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@media(max-width:1024px){.features-grid{grid-template-columns:repeat(3,1fr);gap:1rem}.feature-card{padding:1.5rem 1rem}}@media(max-width:768px){.galaxy-content{padding:1.5rem;gap:1.5rem}.brand-name{font-size:3rem}.login-card-galaxy{max-width:100%}.card-content{padding:2rem 1.5rem}.features-grid{grid-template-columns:1fr;gap:1rem}.security-features{grid-template-columns:1fr}}@media(max-width:480px){.brand-name{font-size:2.5rem}.brand-subtitle{font-size:1rem}.welcome-title{font-size:1.5rem}.card-content{padding:1.5rem 1rem}.galaxy-login-btn{padding:.875rem 1.5rem;font-size:.9375rem}.logo-container{width:100px;height:100px}}.kpi-container{padding:0}.tab-navigation{display:flex;gap:40px;margin-bottom:30px;border-bottom:1px solid #e0e0e0}.tab-btn{background:none;border:none;padding:12px 0;font-size:16px;font-weight:700;color:#202224;cursor:pointer;position:relative;opacity:.6;transition:all .2s}.tab-btn:hover{opacity:1}.tab-btn.active{opacity:1;color:#4880ff}.tab-btn.active:after{content:"";position:absolute;bottom:-1px;left:0;width:100%;height:3px;background-color:#4880ff}.kpi-filter-bar{display:flex;gap:16px;margin-bottom:24px;padding:16px;background:#fff;border-radius:12px;border:.5px solid #d5d5d5;align-items:flex-end}.filter-group{display:flex;flex-direction:column;gap:6px}.filter-group label{font-size:11px;font-weight:700;color:#606060;text-transform:uppercase}.filter-select{padding:8px 12px;border:1px solid #d5d5d5;border-radius:6px;background:#f5f6fa;font-size:13px;min-width:180px;outline:none}.filter-select:focus{border-color:#4880ff}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:24px}.kpi-premium-card{background:#fff;border:.5px solid #d5d5d5;border-radius:14px;padding:24px;display:flex;flex-direction:column;gap:20px;transition:transform .2s ease,box-shadow .2s ease}.kpi-premium-card:hover{transform:translateY(-4px);box-shadow:0 10px 24px #0000000f}.kpi-card-header{display:flex;justify-content:space-between;align-items:flex-start}.kpi-info{display:flex;gap:16px;align-items:center}.kpi-icon-wrapper{width:48px;height:48px;background:#f5f6fa;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px}.kpi-titles h3{margin:0;font-size:18px;font-weight:700;color:#202224}.kpi-titles p{margin:4px 0 0;font-size:12px;font-weight:600;color:#606060}.kpi-performance-circle{width:60px;height:60px;position:relative;display:flex;align-items:center;justify-content:center}.performance-value{font-size:14px;font-weight:800}.performance-value.green{color:#10b981}.performance-value.amber{color:#f59e0b}.performance-value.red{color:#f93c65}.kpi-stats{display:grid;grid-template-columns:1fr 1fr;gap:16px}.stat-box{padding:12px;background:#f8f9fd;border-radius:10px}.stat-label{display:block;font-size:11px;font-weight:600;color:#606060;margin-bottom:4px}.stat-number{display:block;font-size:16px;font-weight:700;color:#202224}.card-action-btn{width:100%;padding:12px;background:#f5f6fa;border:none;border-radius:10px;color:#4880ff;font-weight:700;font-size:14px;cursor:pointer;transition:background .2s;display:flex;align-items:center;justify-content:center;gap:8px}.card-action-btn:hover{background:#e9ebf7}.kpi-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.kpi-modal-content{background:#fff;width:100%;max-width:600px;border-radius:16px;box-shadow:0 20px 40px #0003;overflow:hidden}.modal-header{padding:24px 32px;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;align-items:center}.modal-header h2{margin:0;font-size:24px;font-weight:700}.close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:#a6a6a6}.modal-body{padding:32px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.kpi-form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.kpi-form-group label{font-size:14px;font-weight:700;color:#202224}.kpi-form-group input,.kpi-form-group select,.kpi-form-group textarea{padding:12px 16px;background:#f5f6fa;border:1px solid #d5d5d5;border-radius:8px;font-size:14px;font-family:inherit;outline:none;transition:border-color .2s}.kpi-form-group input:focus,.kpi-form-group select:focus,.kpi-form-group textarea:focus{border-color:#4880ff}.form-footer{padding:24px 32px;background:#fbfbfb;display:flex;justify-content:flex-end;gap:16px}.btn-cancel{padding:10px 24px;background:#fff;border:1px solid #d5d5d5;border-radius:8px;font-weight:700;cursor:pointer}.btn-submit{padding:10px 32px;background:#4880ff;color:#fff;border:none;border-radius:8px;font-weight:700;cursor:pointer}.kpi-infographic-section{display:grid;grid-template-columns:1fr 2fr;gap:24px;margin-bottom:40px}.chart-card{background:#fff;padding:24px;border-radius:14px;border:.5px solid #d5d5d5;box-shadow:0 4px 10px #00000005}.chart-title{font-size:16px;font-weight:700;margin-bottom:20px;color:#202224}.kpi-dashboard-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:30px}.kpi-empty-state{text-align:center;padding:60px;background:#fff;border-radius:14px;border:1px dashed #d5d5d5}.kpi-empty-state h3{margin:16px 0 8px;font-size:18px}.kpi-empty-state p{color:#606060}.staff-module{padding:0;min-height:100%;background:#f8f9fd;font-family:Inter,Segoe UI,sans-serif}.staff-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:400px;gap:16px;color:#666}.staff-page-header{margin-bottom:24px}.staff-page-title{display:flex;align-items:center;gap:10px}.staff-page-title h1{font-size:1.5rem;font-weight:700;color:#121212;margin:0;line-height:1.2}.staff-page-title p{font-size:.875rem;color:#6b7280;margin:2px 0 0}.manager-badge{display:inline-flex;align-items:center;padding:4px 12px;background:#e0f2fe;color:#0369a1;border:1px solid #7dd3fc;border-radius:20px;font-size:.8rem;font-weight:600;letter-spacing:.3px}.readonly-badge{display:inline-flex;align-items:center;padding:4px 12px;background:#fff3cd;color:#856404;border:1px solid #ffc107;border-radius:20px;font-size:.8rem;font-weight:600;letter-spacing:.3px}.my-profile-no-record{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:80px 24px;text-align:center;color:#6b7280}.my-profile-no-record h2{font-size:1.25rem;font-weight:700;color:#121212;margin:0}.my-profile-no-record p{font-size:.9375rem;line-height:1.6;margin:0}.staff-page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.my-profile-card{display:flex;gap:32px;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000f;padding:32px;margin-bottom:20px}.my-profile-photo{display:flex;flex-direction:column;align-items:center;gap:8px;flex-shrink:0;width:160px;text-align:center}.my-profile-photo img{width:100px;height:100px;border-radius:50%;object-fit:cover;border:3px solid #e5e7eb}.my-profile-avatar-placeholder{width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,#0089ff,#0061cc);color:#fff;font-size:2rem;font-weight:700;display:flex;align-items:center;justify-content:center}.my-profile-name{font-size:1.1rem;font-weight:700;color:#121212;margin-top:4px}.my-profile-title{font-size:.875rem;color:#0089ff;font-weight:500}.my-profile-id{font-size:.8125rem;color:#9ca3af;background:#f3f4f6;padding:2px 10px;border-radius:20px}.my-profile-details{flex:1;min-width:0}.my-profile-section-title{font-size:.875rem;font-weight:700;color:#0089ff;text-transform:uppercase;letter-spacing:.5px;margin-bottom:14px;padding-bottom:8px;border-bottom:1.5px solid #f0f0f0}.my-profile-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px 24px}.my-profile-field{display:flex;flex-direction:column;gap:3px}.my-profile-field span{font-size:.75rem;color:#9ca3af;font-weight:500;text-transform:uppercase;letter-spacing:.4px}.my-profile-field strong{font-size:.9rem;color:#121212;font-weight:600;word-break:break-word}.status-pill{display:inline-block;padding:2px 10px;border-radius:20px;font-size:.8rem!important;font-weight:600!important}.status-pill.active{background:#d1fae5;color:#065f46}.status-pill.inactive{background:#f3f4f6;color:#6b7280}.status-pill.on\ leave{background:#fef3c7;color:#92400e}.status-pill.terminated{background:#fee2e2;color:#991b1b}@media(max-width:700px){.my-profile-card{flex-direction:column;align-items:center;padding:20px 16px}.my-profile-photo{width:100%}}.staff-toolbar{display:flex;align-items:flex-end;gap:20px;background:#fff;border-radius:10px;padding:20px 24px;margin-bottom:20px;box-shadow:0 1px 3px #0000000d;flex-wrap:wrap}.toolbar-label{display:block;font-size:.8125rem;font-weight:500;color:#383838;margin-bottom:8px}.staff-search-wrap{flex:1;min-width:200px;max-width:380px}.staff-search-box{display:flex;align-items:center;border:1.5px solid #D9D9D9;border-radius:8px;padding:0 12px;background:#fff;height:50px;gap:8px}.staff-search-box input{border:none;outline:none;flex:1;font-size:.9rem;color:#121212;background:transparent}.staff-search-box input::placeholder{color:#a3a3a3}.staff-total-box{text-align:center;min-width:140px}.staff-total-num{font-size:2rem;font-weight:700;color:#121212;line-height:1}.staff-total-label{font-size:.8125rem;color:#6b7280;margin-top:4px}.staff-filter-wrap{min-width:180px}.staff-filter-select{display:flex;align-items:center;justify-content:space-between;border:1.5px solid #D9D9D9;border-radius:8px;padding:0 14px;height:50px;background:#fff;cursor:pointer;position:relative;font-size:.9rem;color:#383838;-webkit-user-select:none;user-select:none}.filter-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 8px 20px #0000001f;z-index:100;overflow:hidden}.filter-option{padding:12px 16px;font-size:.9rem;color:#383838;cursor:pointer;transition:background .15s}.filter-option:hover{background:#f0f7ff}.filter-option.active{color:#0089ff;font-weight:600;background:#f0f7ff}.btn-add-new-staff{height:50px;padding:0 28px;background:linear-gradient(135deg,#0089ff,#0061cc);color:#fff;border:none;border-radius:8px;font-size:.9375rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .2s;box-shadow:0 2px 8px #0089ff4d;align-self:flex-end}.btn-add-new-staff:hover{background:linear-gradient(135deg,#007aee,#05b);box-shadow:0 4px 14px #0089ff66;transform:translateY(-1px)}.staff-table-card{background:#fff;border-radius:10px;box-shadow:0 1px 3px #0000000d;overflow:hidden;margin-bottom:24px}.table-card-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px}.table-card-header h2{font-size:1.125rem;font-weight:700;color:#121212;margin:0}.per-page-wrap{display:flex;align-items:center;gap:8px;font-size:.875rem;color:#6b7280}.per-page-box{width:40px;height:32px;border:1.5px solid #0089FF;border-radius:6px;display:flex;align-items:center;justify-content:center;font-weight:600;color:#0089ff;font-size:.9rem}.staff-table{width:100%;border-collapse:collapse}.staff-table thead tr{border-bottom:1px solid #f0f0f0}.staff-table th{padding:12px 16px;text-align:left;font-size:.8rem;font-weight:600;color:#383838;white-space:nowrap}.staff-table td{padding:14px 16px;font-size:.875rem;color:#383838;border-bottom:1px solid #f7f7f7}.staff-table tbody tr:last-child td{border-bottom:none}.staff-table tbody tr:hover{background:#f9fbff}.empty-row{text-align:center;padding:48px!important;color:#9ca3af;font-size:.9rem}.view-more-btn{color:#0089ff;font-size:.875rem;font-weight:500;cursor:pointer;text-decoration:none;transition:color .15s}.view-more-btn:hover{color:#0061cc;text-decoration:underline}.staff-pagination{display:flex;align-items:center;gap:6px;padding:16px 24px;border-top:1px solid #f0f0f0}.page-btn{width:36px;height:36px;border-radius:8px;border:1.5px solid #e5e7eb;background:#fff;font-size:.875rem;font-weight:500;color:#383838;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}.page-btn:hover{border-color:#0089ff;color:#0089ff}.page-btn.active{background:#0089ff;border-color:#0089ff;color:#fff;font-weight:700}.staff-back-btn{display:inline-flex;align-items:center;gap:6px;background:none;border:none;color:#0089ff;font-size:.9375rem;font-weight:600;cursor:pointer;padding:0;margin-bottom:20px;transition:color .15s}.staff-back-btn:hover{color:#0061cc}.staff-form-card{background:#fff;border-radius:10px;box-shadow:0 1px 3px #0000000d;padding:28px 32px 36px;margin-bottom:20px}.staff-form-card h2{font-size:1.25rem;font-weight:700;color:#121212;margin:0 0 28px}.staff-form-layout{display:flex;gap:40px;align-items:flex-start}.staff-photo-col{display:flex;flex-direction:column;align-items:center;gap:16px;flex-shrink:0;width:200px}.photo-upload-area{width:140px;height:140px;border-radius:50%;border:2px dashed #D9D9D9;display:flex;align-items:center;justify-content:center;cursor:pointer;overflow:hidden;position:relative;background:#fafafa;transition:border-color .2s}.photo-upload-area:hover{border-color:#0089ff}.photo-placeholder{display:flex;flex-direction:column;align-items:center;gap:8px;color:#aaa;font-size:.8125rem;text-align:center;padding:12px}.photo-preview-wrap{width:100%;height:100%;position:relative}.photo-img{width:100%;height:100%;object-fit:cover}.photo-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0006;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.8125rem;font-weight:600;opacity:0;transition:opacity .2s;border-radius:50%}.photo-upload-area:hover .photo-overlay{opacity:1}.photo-info{display:flex;flex-direction:column;align-items:center;gap:2px;font-size:.8125rem;color:#6b7280;text-align:center}.photo-info strong{color:#383838;font-weight:600}.btn-add-staff-form{width:100%;height:48px;background:linear-gradient(135deg,#0089ff,#0061cc);color:#fff;border:none;border-radius:8px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #0089ff4d;margin-top:8px}.btn-add-staff-form:hover:not(:disabled){background:linear-gradient(135deg,#007aee,#05b);box-shadow:0 4px 14px #0089ff66}.btn-add-staff-form:disabled{opacity:.7;cursor:not-allowed}.staff-fields-col{flex:1;min-width:0}.staff-fields-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px 24px}.sf-group{display:flex;flex-direction:column;gap:6px}.sf-group label{font-size:.875rem;font-weight:500;color:#383838}.sf-group input,.sf-group select{height:50px;padding:0 14px;border:1.5px solid #D9D9D9;border-radius:8px;font-size:.9rem;color:#121212;background:#fff;outline:none;transition:border-color .2s;-moz-appearance:none;appearance:none;-webkit-appearance:none;width:100%;box-sizing:border-box}.sf-group input:focus{border-color:#0089ff;box-shadow:0 0 0 3px #0089ff14}.sf-group input::placeholder{color:#a3a3a3}.sf-readonly{background:#f5f5f5!important;color:#6b7280!important}.sf-select-wrap{position:relative;display:flex;align-items:center}.sf-select-wrap select{padding-right:36px;cursor:pointer}.sf-select-wrap select:focus{border-color:#0089ff;box-shadow:0 0 0 3px #0089ff14}.sf-select-wrap>svg{position:absolute;right:12px;pointer-events:none}.sf-edit-btn-group{justify-content:flex-end;align-self:end}.btn-edit-profile{height:50px;width:100%;background:linear-gradient(135deg,#0089ff,#0061cc);color:#fff;border:none;border-radius:8px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #0089ff4d}.btn-edit-profile:hover:not(:disabled){background:linear-gradient(135deg,#007aee,#05b);box-shadow:0 4px 14px #0089ff66}.btn-edit-profile:disabled{opacity:.7;cursor:not-allowed}.assign-role-card{background:#fff;border-radius:10px;box-shadow:0 1px 3px #0000000d;padding:28px 32px 32px;margin-bottom:20px}.assign-role-card h2{font-size:1.125rem;font-weight:700;color:#121212;margin:0 0 24px}.assign-role-row{display:flex;align-items:flex-end;gap:20px;flex-wrap:wrap}.assign-role-row .sf-group{flex:1;min-width:180px}.btn-assign-submit{height:50px;padding:0 40px;background:linear-gradient(135deg,#0089ff,#0061cc);color:#fff;border:none;border-radius:8px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #0089ff4d;white-space:nowrap;flex-shrink:0;align-self:flex-end}.btn-assign-submit:hover:not(:disabled){background:linear-gradient(135deg,#007aee,#05b)}.btn-assign-submit:disabled{opacity:.7;cursor:not-allowed}.extra-section-card{background:#fff;border-radius:10px;box-shadow:0 1px 3px #0000000d;padding:24px 32px 28px;margin-bottom:16px}.extra-section-header{display:flex;align-items:center;gap:10px;margin-bottom:20px;padding-bottom:14px;border-bottom:1.5px solid #F0F0F0}.extra-section-header h2{font-size:1rem;font-weight:700;color:#121212;margin:0}.extra-section-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:18px 24px}.extra-section-save-row{display:flex;justify-content:flex-end;margin-top:24px;padding-top:16px;border-top:1px solid #F0F0F0}.btn-save-details{height:46px;padding:0 36px;background:linear-gradient(135deg,#0089ff,#0061cc);color:#fff;border:none;border-radius:8px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #0089ff4d}.btn-save-details:hover:not(:disabled){background:linear-gradient(135deg,#007aee,#05b);box-shadow:0 4px 14px #0089ff66}.btn-save-details:disabled{opacity:.7;cursor:not-allowed}@media(max-width:700px){.extra-section-card{padding:20px 16px}.extra-section-grid{grid-template-columns:1fr}.extra-section-save-row{justify-content:stretch}.btn-save-details{width:100%}}.success-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:1000}.success-modal{background:#fff;border-radius:16px;padding:40px 48px;width:300px;text-align:center;box-shadow:0 20px 40px #00000026;animation:scaleIn .25s ease}@keyframes scaleIn{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}.success-check{margin-bottom:20px}.success-modal p{font-size:1rem;color:#383838;margin:0 0 24px;font-weight:500;line-height:1.5}.btn-success-done{width:100%;height:46px;background:linear-gradient(135deg,#0089ff,#0061cc);color:#fff;border:none;border-radius:8px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-success-done:hover{background:linear-gradient(135deg,#007aee,#05b)}.staff-copyright{text-align:center;font-size:.8125rem;color:#9ca3af;padding:16px 0 8px}@media(max-width:900px){.staff-form-layout{flex-direction:column;align-items:center}.staff-photo-col{width:100%;max-width:300px}.staff-fields-grid{grid-template-columns:1fr}.sf-edit-btn-group{align-self:stretch}}@media(max-width:700px){.staff-toolbar{flex-direction:column;align-items:stretch}.staff-search-wrap,.staff-filter-wrap{max-width:100%}.staff-total-box{text-align:left}.staff-table{font-size:.8rem}.staff-table th,.staff-table td{padding:10px}.staff-form-card,.assign-role-card{padding:20px 16px}.assign-role-row{flex-direction:column}.btn-assign-submit{width:100%}}.main-layout{display:flex;min-height:100vh;background-color:#f5f6fa;font-family:Nunito Sans,sans-serif}.sidebar{width:240px;background-color:#fff;display:flex;flex-direction:column;position:fixed;height:100vh;left:0;top:0;z-index:1000;border-right:1px solid #e0e0e0}.sidebar-logo{padding:24px;display:flex;align-items:center;gap:12px;font-weight:800;font-size:20px;color:#202224}.sidebar-menu{flex:1;overflow-y:auto;padding:12px 0}.menu-item{display:flex;align-items:center;padding:12px 24px;gap:16px;color:#202224;text-decoration:none;font-weight:600;font-size:14px;transition:all .2s ease;opacity:.7;cursor:pointer}.menu-item:hover{opacity:1;background-color:#f5f6fa}.menu-item.active{opacity:1;color:#4880ff;border-left:4px solid #4880ff;background-color:#f5f6fa;padding-left:20px}.menu-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center}.sidebar-footer{padding:24px;border-top:1px solid #f0f0f0}.logout-item{display:flex;align-items:center;gap:16px;color:#202224;opacity:.7;font-weight:600;cursor:pointer}.logout-item:hover{opacity:1;color:#ef4444}.main-content{flex:1;margin-left:240px;display:flex;flex-direction:column;min-width:0}.top-bar{height:70px;background-color:#fff;display:flex;align-items:center;justify-content:space-between;padding:0 40px;position:sticky;top:0;z-index:900;box-shadow:0 2px 4px #00000005}.top-bar-left{display:flex;align-items:center;gap:24px}.search-box{position:relative;width:380px}.search-box input{width:100%;padding:10px 16px 10px 48px;background:#f5f6fa;border:1px solid #d5d5d5;border-radius:20px;font-size:14px;outline:none}.search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:#202224;opacity:.5}.top-bar-right{display:flex;align-items:center;gap:32px}.notifications{position:relative;cursor:pointer}.noti-badge{position:absolute;top:-8px;right:-8px;background-color:#f93c65;color:#fff;font-size:10px;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid white}.user-profile{display:flex;align-items:center;gap:12px;cursor:pointer}.user-avatar{width:44px;height:44px;border-radius:50%;overflow:hidden;border:1px solid #eee}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-meta{display:flex;flex-direction:column}.user-meta .name{font-weight:700;font-size:14px;color:#404040}.user-meta .role{font-weight:600;font-size:12px;color:#565656}.dropdown-icon{margin-left:4px;opacity:.5}.page-body{padding:30px;flex:1}.page-title{font-weight:700;font-size:32px;color:#202224;margin-bottom:24px}.content-card{background:#fff;border:.3px solid #b9b9b9;border-radius:14px;padding:40px;box-shadow:0 4px 6px #00000005}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:600;font-size:14px;color:#606060}.form-group input,.form-group select{padding:12px 16px;background:#f5f6fa;border:1px solid #d5d5d5;border-radius:8px;font-size:14px;color:#202224;outline:none}.form-group input::placeholder{color:#a6a6a6}.btn-primary{background-color:#4880ff;color:#fff;border:none;padding:12px 40px;border-radius:12px;font-weight:700;font-size:18px;cursor:pointer;transition:opacity .2s;align-self:center;margin-top:40px}.btn-primary:hover{opacity:.9}.photo-upload{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:40px}.photo-placeholder{width:80px;height:80px;background:#f5f6fa;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#202224;font-size:24px}.upload-link{color:#4880ff;font-weight:600;font-size:14px;text-decoration:none}:root{--primary: #6366f1;--primary-dark: #4f46e5;--primary-light: #818cf8;--secondary: #8b5cf6;--success: #10b981;--warning: #f59e0b;--error: #ef4444;--info: #3b82f6;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--bg-primary: #ffffff;--bg-secondary: #f9fafb;--bg-tertiary: #f3f4f6;--text-primary: #111827;--text-secondary: #6b7280;--text-tertiary: #9ca3af;--border-color: #e5e7eb;--border-radius: 12px;--border-radius-sm: 8px;--border-radius-lg: 16px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-md: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-lg: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--shadow-xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--transition: all .2s cubic-bezier(.4, 0, .2, 1);--transition-fast: all .15s cubic-bezier(.4, 0, .2, 1);--spacing-xs: .5rem;--spacing-sm: .75rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--text-primary);background:var(--bg-secondary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:var(--spacing-lg)}.spinner{width:40px;height:40px;border:3px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.spinner.large{width:60px;height:60px;border-width:4px}@keyframes spin{to{transform:rotate(360deg)}}.spinner-small{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg);background:linear-gradient(135deg,#667eea,#764ba2);position:relative;overflow:hidden}.login-container:before{content:"";position:absolute;top:-50%;right:-50%;width:100%;height:100%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);animation:float 20s ease-in-out infinite}@keyframes float{0%,to{transform:translate(0) rotate(0)}50%{transform:translate(-20px,20px) rotate(5deg)}}.login-card{background:var(--bg-primary);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-xl);max-width:480px;width:100%;overflow:hidden;position:relative;z-index:1;animation:slideUp .5s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);color:#fff;padding:var(--spacing-2xl);text-align:center}.logo-container{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md)}.logo-icon{width:60px;height:60px;background:#fff3;border-radius:var(--border-radius);display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.logo-icon svg{width:32px;height:32px}.logo-icon.small{width:40px;height:40px}.logo-icon.small svg{width:24px;height:24px}.login-header h1{font-size:2rem;font-weight:700;margin:0}.subtitle{font-size:.95rem;opacity:.9;margin-top:var(--spacing-sm)}.login-content{padding:var(--spacing-2xl)}.login-content h2{font-size:1.75rem;font-weight:600;margin-bottom:var(--spacing-sm);color:var(--text-primary)}.description{color:var(--text-secondary);margin-bottom:var(--spacing-xl);font-size:.95rem}.error-message{background:#fee2e2;border:1px solid #fecaca;color:#991b1b;padding:var(--spacing-md);border-radius:var(--border-radius-sm);margin-bottom:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-sm);font-size:.9rem}.error-message svg{width:20px;height:20px;flex-shrink:0}.microsoft-login-btn{width:100%;padding:var(--spacing-md) var(--spacing-lg);background:#fff;border:2px solid var(--gray-300);border-radius:var(--border-radius);font-size:1rem;font-weight:600;color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);transition:var(--transition);box-shadow:var(--shadow-sm)}.microsoft-login-btn:hover:not(:disabled){border-color:var(--gray-400);box-shadow:var(--shadow-md);transform:translateY(-2px)}.microsoft-login-btn:active:not(:disabled){transform:translateY(0)}.microsoft-login-btn:disabled{opacity:.6;cursor:not-allowed}.microsoft-login-btn svg{width:20px;height:20px}.features{margin-top:var(--spacing-xl);padding-top:var(--spacing-xl);border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:var(--spacing-md)}.feature{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--text-secondary);font-size:.9rem}.feature svg{width:18px;height:18px;color:var(--success);flex-shrink:0}.dashboard{min-height:100vh;background:var(--bg-secondary)}.dashboard-header{background:var(--bg-primary);border-bottom:1px solid var(--border-color);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:100}.header-content{max-width:1400px;margin:0 auto;padding:var(--spacing-lg) var(--spacing-xl);display:flex;align-items:center;justify-content:space-between}.logo-section{display:flex;align-items:center;gap:var(--spacing-md)}.app-name{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.user-section{display:flex;align-items:center;gap:var(--spacing-lg)}.user-info{display:flex;flex-direction:column;align-items:flex-end}.user-name{font-weight:600;color:var(--text-primary)}.user-roles{font-size:.85rem;color:var(--text-secondary)}.logout-btn{padding:var(--spacing-sm) var(--spacing-lg);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);font-weight:500;color:var(--text-primary);cursor:pointer;display:flex;align-items:center;gap:var(--spacing-sm);transition:var(--transition)}.logout-btn:hover{background:var(--gray-200);border-color:var(--gray-300)}.logout-btn svg{width:18px;height:18px}.dashboard-main{max-width:1400px;margin:0 auto;padding:var(--spacing-2xl) var(--spacing-xl)}.welcome-section{margin-bottom:var(--spacing-2xl)}.welcome-section h1{font-size:2.5rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.welcome-section p{font-size:1.1rem;color:var(--text-secondary)}.admin-banner{background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);color:#fff;padding:var(--spacing-lg);border-radius:var(--border-radius);display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xl);box-shadow:var(--shadow-md)}.admin-banner svg{width:24px;height:24px;flex-shrink:0}.admin-banner span{flex:1;font-weight:500}.admin-link{padding:var(--spacing-sm) var(--spacing-lg);background:#fff3;border:1px solid rgba(255,255,255,.3);border-radius:var(--border-radius-sm);color:#fff;font-weight:600;cursor:pointer;transition:var(--transition);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.admin-link:hover{background:#ffffff4d;transform:translate(4px)}.modules-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--spacing-xl)}.module-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:var(--spacing-xl);transition:var(--transition);position:relative;overflow:hidden}.module-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--module-color, var(--primary));transform:scaleX(0);transition:var(--transition)}.module-card:hover:not(.disabled):before{transform:scaleX(1)}.module-card:hover:not(.disabled){box-shadow:var(--shadow-lg);transform:translateY(-4px);cursor:pointer}.module-card.disabled{opacity:.6;cursor:not-allowed}.module-icon{font-size:3rem;margin-bottom:var(--spacing-md)}.module-card h3{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.module-card p{color:var(--text-secondary);margin-bottom:var(--spacing-lg);line-height:1.5}.module-access{display:flex;flex-direction:column;gap:var(--spacing-md)}.access-badges{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.badge{padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--border-radius-sm);font-size:.85rem;font-weight:600;display:flex;align-items:center;gap:var(--spacing-xs)}.badge svg{width:14px;height:14px}.badge.read{background:#dbeafe;color:#1e40af}.badge.write{background:#dcfce7;color:#166534}.module-btn{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--module-color, var(--primary));color:#fff;border:none;border-radius:var(--border-radius-sm);font-weight:600;cursor:pointer;transition:var(--transition)}.module-btn:hover{opacity:.9;transform:translate(4px)}.no-access{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--text-tertiary);font-size:.9rem}.no-access svg{width:18px;height:18px}.admin-panel{min-height:100vh;background:var(--bg-secondary)}.admin-header{background:var(--bg-primary);border-bottom:1px solid var(--border-color);box-shadow:var(--shadow-sm);padding:var(--spacing-xl)}.back-btn{padding:var(--spacing-sm) var(--spacing-lg);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);font-weight:500;color:var(--text-primary);cursor:pointer;display:inline-flex;align-items:center;gap:var(--spacing-sm);transition:var(--transition);margin-bottom:var(--spacing-md)}.back-btn:hover{background:var(--gray-200)}.back-btn svg{width:18px;height:18px}.admin-header h1{font-size:2rem;font-weight:700;color:var(--text-primary)}.admin-content{max-width:1400px;margin:0 auto;padding:var(--spacing-2xl) var(--spacing-xl)}.tabs{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-xl);border-bottom:2px solid var(--border-color)}.tab{padding:var(--spacing-md) var(--spacing-lg);background:none;border:none;border-bottom:3px solid transparent;font-weight:600;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;gap:var(--spacing-sm);transition:var(--transition);margin-bottom:-2px}.tab svg{width:20px;height:20px}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--primary);border-bottom-color:var(--primary)}.section-header{margin-bottom:var(--spacing-xl)}.section-header h2{font-size:1.75rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.section-header p{color:var(--text-secondary)}.users-table{display:flex;flex-direction:column;gap:var(--spacing-md)}.user-row{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:var(--spacing-lg);display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-lg);transition:var(--transition)}.user-row:hover{box-shadow:var(--shadow-md)}.user-info-section{display:flex;align-items:center;gap:var(--spacing-md);flex:1}.user-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.25rem;flex-shrink:0}.user-details h3{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:2px}.user-details p{font-size:.9rem;color:var(--text-secondary)}.user-roles-section{display:flex;align-items:center;gap:var(--spacing-md);flex:1}.assigned-roles{display:flex;gap:var(--spacing-sm);flex-wrap:wrap;flex:1}.role-badge{padding:var(--spacing-xs) var(--spacing-md);background:var(--primary);color:#fff;border-radius:var(--border-radius-sm);font-size:.85rem;font-weight:600;display:flex;align-items:center;gap:var(--spacing-xs)}.remove-role-btn{background:#fff3;border:none;color:#fff;width:18px;height:18px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.2rem;line-height:1;transition:var(--transition)}.remove-role-btn:hover{background:#ffffff4d}.no-roles{color:var(--text-tertiary);font-size:.9rem;font-style:italic}.role-select{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);background:var(--bg-primary);color:var(--text-primary);font-size:.9rem;cursor:pointer;transition:var(--transition)}.role-select:hover{border-color:var(--gray-400)}.role-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}.roles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--spacing-xl)}.role-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:var(--spacing-xl);transition:var(--transition)}.role-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.role-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md)}.role-header h3{font-size:1.5rem;font-weight:600;color:var(--text-primary)}.system-badge{padding:var(--spacing-xs) var(--spacing-sm);background:var(--gray-200);color:var(--gray-700);border-radius:var(--border-radius-sm);font-size:.75rem;font-weight:600;text-transform:uppercase}.role-description{color:var(--text-secondary);margin-bottom:var(--spacing-lg);line-height:1.5}.role-permissions h4{font-size:.9rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--spacing-md)}.permissions-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.permission-badge{padding:var(--spacing-xs) var(--spacing-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);font-size:.85rem;color:var(--text-primary)}.no-permissions{color:var(--text-tertiary);font-size:.9rem;font-style:italic}@media(max-width:768px){.header-content{flex-direction:column;gap:var(--spacing-md);align-items:flex-start}.user-section{width:100%;justify-content:space-between}.welcome-section h1{font-size:2rem}.modules-grid{grid-template-columns:1fr}.user-row{flex-direction:column;align-items:flex-start}.user-roles-section{width:100%;flex-direction:column;align-items:flex-start}.roles-grid{grid-template-columns:1fr}}.login-container-modern{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:linear-gradient(135deg,#0f0c29,#302b63,#24243e)}.login-bg-animation{position:absolute;width:100%;height:100%;overflow:hidden}.gradient-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.4;animation:float-orb 20s ease-in-out infinite}.orb-1{width:500px;height:500px;background:linear-gradient(135deg,#667eea,#764ba2);top:-10%;left:-10%;animation-delay:0s}.orb-2{width:400px;height:400px;background:linear-gradient(135deg,#f093fb,#f5576c);bottom:-10%;right:-10%;animation-delay:7s}.orb-3{width:350px;height:350px;background:linear-gradient(135deg,#4facfe,#00f2fe);top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:14s}@keyframes float-orb{0%,to{transform:translate(0) scale(1)}33%{transform:translate(50px,-50px) scale(1.1)}66%{transform:translate(-30px,30px) scale(.9)}}.login-content-wrapper{position:relative;z-index:10;display:grid;grid-template-columns:1fr 1fr;max-width:1200px;width:90%;background:#ffffff0d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;overflow:hidden;box-shadow:0 25px 50px -12px #00000080,0 0 0 1px #ffffff1a;animation:slideIn .8s cubic-bezier(.16,1,.3,1)}@keyframes slideIn{0%{opacity:0;transform:translateY(40px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.login-branding{padding:4rem;background:linear-gradient(135deg,#667eea1a,#764ba21a);display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;border-right:1px solid rgba(255,255,255,.1)}.brand-logo-large{margin-bottom:2rem;animation:pulse-glow 3s ease-in-out infinite}.brand-logo-large svg{width:120px;height:120px;filter:drop-shadow(0 10px 30px rgba(102,126,234,.5))}@keyframes pulse-glow{0%,to{filter:drop-shadow(0 10px 30px rgba(102,126,234,.5))}50%{filter:drop-shadow(0 15px 40px rgba(102,126,234,.8))}}.brand-title{font-size:3.5rem;font-weight:800;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem;letter-spacing:-.02em}.brand-tagline{font-size:1.25rem;color:#ffffffb3;font-weight:300;margin-bottom:3rem;letter-spacing:.05em;text-transform:uppercase}.brand-features{display:flex;flex-direction:column;gap:2rem;width:100%;max-width:400px}.feature-item{display:flex;align-items:center;gap:1.5rem;padding:1.5rem;background:#ffffff0d;border-radius:16px;border:1px solid rgba(255,255,255,.1);transition:all .3s cubic-bezier(.4,0,.2,1)}.feature-item:hover{background:#ffffff1a;transform:translate(10px);border-color:#667eea80}.feature-icon{width:48px;height:48px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.feature-icon svg{width:24px;height:24px;color:#fff}.feature-text{text-align:left}.feature-text h3{font-size:1.1rem;font-weight:600;color:#fff;margin-bottom:.25rem}.feature-text p{font-size:.9rem;color:#fff9}.login-form-panel{padding:4rem;background:#fffffffa;display:flex;align-items:center;justify-content:center}.login-form-content{width:100%;max-width:400px}.form-header{margin-bottom:3rem;text-align:center}.form-header h2{font-size:2.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.form-header p{font-size:1rem;color:var(--text-secondary)}.login-btn-modern{width:100%;padding:1.25rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:16px;color:#fff;font-size:1.1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:1rem;position:relative;overflow:hidden;box-shadow:0 10px 30px -10px #667eea80;transition:all .3s cubic-bezier(.4,0,.2,1)}.login-btn-modern:hover{transform:translateY(-2px);box-shadow:0 15px 40px -10px #667eeab3}.login-btn-modern:active{transform:translateY(0)}.btn-icon{display:flex;align-items:center;justify-content:center}.btn-icon svg{width:24px;height:24px}.btn-shimmer{position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 3s infinite}@keyframes shimmer{0%{left:-100%}to{left:100%}}.login-divider{display:flex;align-items:center;margin:2rem 0;color:var(--text-tertiary);font-size:.85rem;text-transform:uppercase;letter-spacing:.05em}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border-color)}.login-divider span{padding:0 1rem}.security-badges{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:2rem}.security-badges .badge{flex-direction:column;padding:1rem .5rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;text-align:center;transition:all .3s ease}.security-badges .badge:hover{background:var(--bg-tertiary);border-color:var(--primary);transform:translateY(-2px)}.security-badges .badge svg{width:20px;height:20px;color:var(--primary);margin-bottom:.5rem}.security-badges .badge span{font-size:.75rem;color:var(--text-secondary);font-weight:500}.login-footer{text-align:center;padding-top:2rem;border-top:1px solid var(--border-color)}.login-footer p{font-size:.85rem;color:var(--text-tertiary)}.particles{position:absolute;width:100%;height:100%;pointer-events:none}.particle{position:absolute;width:4px;height:4px;background:#ffffff80;border-radius:50%;animation:float-particle 15s infinite}.particle:nth-child(1){left:10%;animation-delay:0s}.particle:nth-child(2){left:30%;animation-delay:3s}.particle:nth-child(3){left:50%;animation-delay:6s}.particle:nth-child(4){left:70%;animation-delay:9s}.particle:nth-child(5){left:90%;animation-delay:12s}@keyframes float-particle{0%{bottom:-10%;opacity:0}10%{opacity:1}90%{opacity:1}to{bottom:110%;opacity:0}}@media(max-width:968px){.login-content-wrapper{grid-template-columns:1fr;width:95%}.login-branding{padding:3rem 2rem;border-right:none;border-bottom:1px solid rgba(255,255,255,.1)}.brand-title{font-size:2.5rem}.brand-features{display:none}.login-form-panel{padding:3rem 2rem}.security-badges{grid-template-columns:1fr}}
