.layout{display:flex;min-height:100vh;background:var(--gray-100)}.mobile-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:998}.sidebar{width:260px;background:linear-gradient(180deg,#1a365d,#0f172a);color:#fff;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:999;transition:all .3s ease}.sidebar-header{display:flex;align-items:center;padding:1.25rem 1rem;border-bottom:1px solid rgba(255,255,255,.1);gap:.75rem}.sidebar-logo{flex-shrink:0}.sidebar-logo svg{filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.sidebar-title{font-family:Playfair Display,serif;font-size:1.375rem;font-weight:700;color:#d4af37;letter-spacing:.1em}.sidebar-toggle{margin-left:auto;background:#ffffff1a;border:none;color:#fff;width:28px;height:28px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.sidebar-toggle:hover{background:#fff3}.sidebar-nav{flex:1;padding:1rem .75rem;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:.875rem;padding:.75rem 1rem;color:#ffffffb3;text-decoration:none;border-radius:8px;margin-bottom:.25rem;transition:all .2s ease;font-size:.875rem;font-weight:500;cursor:pointer;border:none;background:none;width:100%;text-align:left}.nav-item:hover{background:#ffffff14;color:#fff}.nav-item.active{background:linear-gradient(135deg,#d4af3733,#d4af371a);color:#d4af37;font-weight:600}.nav-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:24px;background:#d4af37;border-radius:0 2px 2px 0}.nav-item svg{flex-shrink:0}.logout-btn{color:#fff9}.logout-btn:hover{background:#e53e3e33;color:#fc8181}.sidebar-footer{padding:.75rem;border-top:1px solid rgba(255,255,255,.1)}.main-content{flex:1;margin-left:260px;display:flex;flex-direction:column;min-height:100vh;transition:margin-left .3s ease}.top-bar{display:flex;align-items:center;justify-content:flex-end;padding:1rem 1.5rem;background:#fff;border-bottom:1px solid var(--gray-200);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:100}.mobile-menu-btn{display:none;background:none;border:none;color:var(--gray-700);cursor:pointer;padding:.5rem;border-radius:6px}.mobile-menu-btn:hover{background:var(--gray-100)}.top-bar-right{display:flex;align-items:center;gap:1rem}.user-info{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background:var(--gray-50);border-radius:10px;cursor:pointer;transition:all .2s ease}.user-info:hover{background:var(--gray-100)}.user-avatar{width:36px;height:36px;background:linear-gradient(135deg,#1a365d,#4a90d9);color:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem}.user-details{display:flex;flex-direction:column}.user-name{font-size:.8125rem;font-weight:600;color:var(--gray-900)}.user-role{font-size:.6875rem;color:var(--gray-500);text-transform:capitalize}.user-chevron{color:var(--gray-400)}.page-content{flex:1;padding:1.5rem}@media (max-width: 1024px){.sidebar{width:220px}.main-content{margin-left:220px}}@media (max-width: 768px){.sidebar{transform:translate(-100%);width:260px}.sidebar.mobile-open{transform:translate(0)}.main-content{margin-left:0}.mobile-menu-btn{display:flex}.user-details,.user-chevron{display:none}.page-content{padding:1rem}}@media (max-width: 480px){.top-bar{padding:.75rem 1rem}.user-info{padding:.375rem .5rem}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#0f172a,#1a365d,#1e4976);position:relative;overflow:hidden}.login-bg-pattern{position:absolute;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(circle at 20% 80%,rgba(212,175,55,.08) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(74,144,217,.1) 0%,transparent 50%),radial-gradient(circle at 50% 50%,rgba(255,255,255,.02) 0%,transparent 70%);z-index:0}.login-content{display:grid;grid-template-columns:1fr 1.2fr;max-width:1050px;width:100%;background:#fff;border-radius:24px;overflow:hidden;box-shadow:0 25px 50px -12px #00000040;position:relative;z-index:1;animation:fadeIn .5s ease-out}.login-branding{background:linear-gradient(135deg,#1a365d,#0f172a);padding:4rem 3rem;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;position:relative}.login-branding:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:linear-gradient(45deg,transparent 49.5%,rgba(212,175,55,.1) 49.5%,rgba(212,175,55,.1) 50.5%,transparent 50.5%);background-size:30px 30px;opacity:.5}.logo-container{margin-bottom:2rem;position:relative;z-index:1}.login-logo{width:120px;height:120px;filter:drop-shadow(0 10px 20px rgba(0,0,0,.3))}.brand-title{font-family:Playfair Display,serif;font-size:3.5rem;font-weight:700;color:#d4af37;letter-spacing:.15em;margin-bottom:.5rem;position:relative;z-index:1;text-shadow:0 2px 10px rgba(212,175,55,.3)}.brand-subtitle{font-size:.875rem;font-weight:500;color:#ffffffb3;text-transform:uppercase;letter-spacing:.1em;margin-bottom:2rem;position:relative;z-index:1}.brand-divider{width:60px;height:2px;background:linear-gradient(90deg,transparent,#d4af37,transparent);margin-bottom:2rem;position:relative;z-index:1}.brand-desc{font-size:.9375rem;color:#fff9;line-height:1.6;max-width:280px;position:relative;z-index:1}.login-form-container{padding:3rem 2.5rem;display:flex;flex-direction:column;justify-content:center}.form-title{font-size:1.625rem;font-weight:700;color:#1a365d;margin-bottom:.375rem}.form-subtitle{font-size:.875rem;color:#718096;margin-bottom:1.75rem}.role-grid-compact{display:grid;grid-template-columns:repeat(5,1fr);gap:.5rem;margin-bottom:1.5rem}.role-btn{display:flex;flex-direction:column;align-items:center;gap:.375rem;padding:.75rem .375rem;border:2px solid #e2e8f0;border-radius:10px;background:#fff;cursor:pointer;transition:all .2s ease;text-align:center;position:relative}.role-btn:hover{border-color:var(--role-color, #4a90d9);background:#4a90d908}.role-btn.selected{border-color:var(--role-color, #4a90d9);background:linear-gradient(135deg,#4a90d914,#d4af370d);box-shadow:0 4px 12px #0000001a}.role-btn svg{color:var(--role-color, #718096);transition:color .2s ease}.role-btn.selected svg{color:var(--role-color, #d4af37)}.role-btn span{font-size:.6875rem;font-weight:600;color:#4a5568;line-height:1.2}.role-btn.selected span{color:var(--role-color, #1a365d)}.role-check-mark{position:absolute;top:6px;right:6px;width:16px;height:16px;background:linear-gradient(135deg,#d4af37,#f0d060);border-radius:50%}.role-check-mark:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:9px;color:#1a365d;font-weight:700}.login-form-fields{display:flex;flex-direction:column;gap:1rem}.login-form-fields .form-group{margin-bottom:0}.login-form-fields .form-label{display:flex;align-items:center;margin-bottom:.375rem;font-size:.8125rem;font-weight:500;color:#4a5568}.login-form-fields .form-input{padding:.75rem .875rem;border:1.5px solid #e2e8f0;border-radius:10px;font-size:.875rem;transition:all .2s ease;background:#f7fafc}.login-form-fields .form-input:focus{border-color:#4a90d9;box-shadow:0 0 0 3px #4a90d926;background:#fff;outline:none}.login-form-fields .form-input::placeholder{color:#a0aec0;font-size:.8125rem}.error-message{display:flex;align-items:center;gap:.5rem;padding:.75rem .875rem;background:#fff5f5;border:1px solid #fed7d7;border-radius:8px;color:#c53030;font-size:.8125rem}.error-message svg{flex-shrink:0}.btn-login{width:100%;padding:.875rem 1rem;background:linear-gradient(135deg,#1a365d,#2d5a8e);color:#fff;border:none;border-radius:10px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .25s ease;display:flex;align-items:center;justify-content:center;gap:.625rem;margin-top:.5rem}.btn-login:hover:not(:disabled){background:linear-gradient(135deg,#1e4976,#1a365d);box-shadow:0 8px 20px #1a365d4d;transform:translateY(-2px)}.btn-login:active:not(:disabled){transform:translateY(0)}.btn-login:disabled{opacity:.6;cursor:not-allowed}.spinner-icon{animation:spin 1s linear infinite}.login-footer{margin-top:1.25rem;text-align:center;padding-top:1rem;border-top:1px solid #e2e8f0}.login-footer p{font-size:.6875rem;color:#a0aec0}@keyframes fadeIn{0%{opacity:0;transform:scale(.97) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}@media (max-width: 1024px){.role-grid-compact{grid-template-columns:repeat(3,1fr)}}@media (max-width: 900px){.login-content{grid-template-columns:1fr;max-width:500px}.login-branding{padding:2.5rem 2rem 2rem}.login-form-container{padding:2rem}.brand-title{font-size:2.5rem}.login-logo{width:90px;height:90px}.role-grid-compact{grid-template-columns:repeat(3,1fr)}}@media (max-width: 480px){.login-container{padding:1rem}.login-form-container{padding:1.5rem}.form-title{font-size:1.375rem}.role-grid-compact{grid-template-columns:repeat(2,1fr)}.role-btn{padding:.625rem .25rem}}.dashboard-loading{display:flex;align-items:center;justify-content:center;min-height:400px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.25rem;margin-bottom:1.5rem}.stat-card{background:#fff;border-radius:var(--radius-lg);padding:1.25rem;display:flex;align-items:center;gap:1rem;box-shadow:var(--shadow);transition:all .2s ease}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card.gold{background:linear-gradient(135deg,#d4af3714,#d4af3708);border:1px solid rgba(212,175,55,.2)}.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-info{display:flex;flex-direction:column}.stat-value{font-size:1.5rem;font-weight:700;color:var(--gray-900)}.stat-label{font-size:.8125rem;color:var(--gray-600);margin-top:.125rem}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.25rem}.dashboard-card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden}.card-header{padding:1.25rem;border-bottom:1px solid var(--gray-200)}.card-header h3{font-size:1rem;font-weight:600}.project-list{padding:1rem 1.25rem}.project-item{padding:1rem 0;border-bottom:1px solid var(--gray-100);display:flex;align-items:center;justify-content:space-between;gap:1rem}.project-item:last-child{border-bottom:none}.project-info{flex:1;min-width:0}.project-code{font-size:.6875rem;font-weight:600;color:var(--primary-600);background:var(--primary-50);padding:.125rem .5rem;border-radius:4px;margin-bottom:.25rem;display:inline-block}.project-name{font-size:.875rem;font-weight:500;color:var(--gray-800);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-progress{display:flex;align-items:center;gap:.5rem;flex:0 0 120px}.progress-bar{flex:1;height:6px;background:var(--gray-200);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-500),var(--primary-400));border-radius:3px;transition:width .3s ease}.progress-text{font-size:.75rem;font-weight:600;color:var(--gray-700);min-width:35px;text-align:right}@media (max-width: 768px){.stats-grid,.dashboard-grid{grid-template-columns:1fr}.project-item{flex-direction:column;align-items:flex-start}.project-progress{width:100%;flex:none}}:root{--primary-900: #0f172a;--primary-800: #1a365d;--primary-700: #1e4976;--primary-600: #2d5a8e;--primary-500: #4a90d9;--primary-400: #6bb3f0;--primary-300: #93ccf5;--primary-200: #b8e0f9;--primary-100: #dbeeff;--primary-50: #eef6ff;--gold-600: #b8941f;--gold-500: #d4af37;--gold-400: #e0c050;--gold-300: #f0d060;--gold-200: #f5e090;--gold-100: #faf0c0;--success: #48bb78;--success-light: #c6f6d5;--warning: #ed8936;--warning-light: #feebc8;--danger: #e53e3e;--danger-light: #fed7d7;--info: #3182ce;--info-light: #bee3f8;--gray-900: #1a202c;--gray-800: #2d3748;--gray-700: #4a5568;--gray-600: #718096;--gray-500: #a0aec0;--gray-400: #cbd5e0;--gray-300: #e2e8f0;--gray-200: #edf2f7;--gray-100: #f7fafc;--gray-50: #fafbfc;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px 0 rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--radius-sm: .25rem;--radius: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--transition: all .2s ease}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background-color:var(--gray-100);color:var(--gray-900);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh}#root{min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2;color:var(--gray-900)}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1.125rem}h5{font-size:1rem}h6{font-size:.875rem}.text-center{text-align:center}.text-right{text-align:right}.text-primary{color:var(--primary-700)}.text-gold{color:var(--gold-500)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}.text-muted{color:var(--gray-600)}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.font-semibold{font-weight:600}.font-bold{font-weight:700}.card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:1.5rem;transition:var(--transition)}.card:hover{box-shadow:var(--shadow-md)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;border-radius:var(--radius-md);border:none;cursor:pointer;transition:var(--transition);white-space:nowrap}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--primary-700),var(--primary-600));color:#fff}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--primary-800),var(--primary-700));box-shadow:var(--shadow-md)}.btn-gold{background:linear-gradient(135deg,var(--gold-500),var(--gold-400));color:var(--primary-900)}.btn-gold:hover:not(:disabled){background:linear-gradient(135deg,var(--gold-600),var(--gold-500));box-shadow:var(--shadow-md)}.btn-outline{background:transparent;border:1.5px solid var(--gray-300);color:var(--gray-700)}.btn-outline:hover:not(:disabled){border-color:var(--primary-500);color:var(--primary-700);background:var(--primary-50)}.btn-sm{padding:.375rem .875rem;font-size:.8125rem}.btn-lg{padding:.875rem 1.75rem;font-size:1rem}.form-group{margin-bottom:1rem}.form-label{display:block;margin-bottom:.375rem;font-size:.875rem;font-weight:500;color:var(--gray-700)}.form-input,.form-select,.form-textarea{width:100%;padding:.625rem .875rem;font-size:.875rem;border:1.5px solid var(--gray-300);border-radius:var(--radius-md);background:#fff;transition:var(--transition);font-family:inherit}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #4a90d926}.form-textarea{resize:vertical;min-height:100px}.table-container{overflow-x:auto;border-radius:var(--radius-lg);box-shadow:var(--shadow)}table{width:100%;border-collapse:collapse;background:#fff}thead{background:linear-gradient(135deg,var(--primary-800),var(--primary-700));color:#fff}th{padding:.875rem 1rem;text-align:left;font-weight:600;font-size:.8125rem;text-transform:uppercase;letter-spacing:.025em}td{padding:.875rem 1rem;border-bottom:1px solid var(--gray-200);font-size:.875rem}tbody tr:hover{background:var(--gray-50)}tbody tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;padding:.25rem .75rem;font-size:.75rem;font-weight:600;border-radius:9999px;text-transform:capitalize}.badge-success{background:var(--success-light);color:#22543d}.badge-warning{background:var(--warning-light);color:#7b341e}.badge-danger{background:var(--danger-light);color:#742a2a}.badge-info{background:var(--info-light);color:#2a4365}.badge-primary{background:var(--primary-100);color:var(--primary-800)}.grid{display:grid;gap:1.5rem}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-2{gap:.5rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.page-header{margin-bottom:1.5rem}.page-title{font-size:1.75rem;font-weight:700;color:var(--gray-900);margin-bottom:.25rem}.page-subtitle{font-size:.875rem;color:var(--gray-600)}.stats-card{background:linear-gradient(135deg,var(--primary-800),var(--primary-700));color:#fff;border-radius:var(--radius-lg);padding:1.25rem;box-shadow:var(--shadow-md)}.stats-card.gold{background:linear-gradient(135deg,var(--gold-500),var(--gold-400));color:var(--primary-900)}.stats-card .stats-value{font-size:1.875rem;font-weight:700;margin-top:.25rem}.stats-card .stats-label{font-size:.8125rem;opacity:.85;text-transform:uppercase;letter-spacing:.025em}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-fade-in{animation:fadeIn .3s ease-out}.animate-slide-in{animation:slideIn .3s ease-out}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.spinner{border:3px solid var(--gray-200);border-top:3px solid var(--primary-600);border-radius:50%;width:24px;height:24px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 1024px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.page-title{font-size:1.5rem}.btn{padding:.5rem 1rem;font-size:.8125rem}th,td{padding:.625rem .75rem}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--gray-100);border-radius:var(--radius)}::-webkit-scrollbar-thumb{background:var(--gray-400);border-radius:var(--radius)}::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease}.modal-content{background:#fff;border-radius:16px;padding:2rem;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.kanban-board{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:1.5rem;overflow-x:auto;padding-bottom:1rem}.kanban-column{background:var(--gray-100);border-radius:12px;min-height:400px}.kanban-header{display:flex;align-items:center;gap:.5rem;padding:.875rem 1rem;color:#fff;font-weight:600;font-size:.875rem;border-radius:12px 12px 0 0}.kanban-count{margin-left:auto;background:#ffffff40;padding:.125rem .5rem;border-radius:10px;font-size:.75rem}.kanban-body{padding:.75rem;display:flex;flex-direction:column;gap:.75rem}.kanban-card{background:#fff;border-radius:10px;padding:.875rem;box-shadow:var(--shadow-sm);transition:all .2s ease;border:1px solid var(--gray-200)}.kanban-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.kanban-actions{display:flex;gap:.375rem;margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--gray-100)}.kanban-actions button{flex:1;padding:.375rem;border:1px solid var(--gray-300);background:#fff;border-radius:6px;cursor:pointer;font-size:.75rem;transition:all .2s ease}.kanban-actions button:hover{background:var(--primary-50);border-color:var(--primary-500);color:var(--primary-700)}.page{animation:fadeIn .3s ease}@media (max-width: 1024px){.kanban-board{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.kanban-board{grid-template-columns:1fr}.modal-content{padding:1.5rem;margin:1rem}}
