*{box-sizing:border-box;margin:0;padding:0}body{color:#333;background:#f0f2f5;font-family:Ubuntu,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.login-page{justify-content:center;align-items:center;min-height:100vh;display:flex}.login-form{background:#fff;border-radius:8px;width:360px;padding:2rem;box-shadow:0 2px 8px #0000001a}.login-form h2{text-align:center;color:#1a73e8;margin-bottom:1.5rem}.login-form input{border:1px solid #ddd;border-radius:4px;width:100%;margin-bottom:.75rem;padding:.75rem;font-size:.95rem}.login-form button{color:#fff;cursor:pointer;background:#1a73e8;border:none;border-radius:4px;width:100%;padding:.75rem;font-size:1rem}.login-form button:hover{background:#1557b0}.error{color:#c62828;background:#fce4ec;border-radius:4px;margin-bottom:.75rem;padding:.5rem;font-size:.9rem}.app-shell{flex-direction:column;min-height:100vh;display:flex}.top-bar{color:#fff;z-index:10;background:#1a1a2e;flex-shrink:0;justify-content:space-between;align-items:center;height:52px;padding:0 1rem;display:flex}.top-bar-left,.top-bar-right{align-items:center;gap:.75rem;display:flex}.brand{color:#64b5f6;font-size:1.1rem;font-weight:700}.toggle-btn{color:#ccc;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.25rem .5rem;font-size:1.2rem}.toggle-btn:hover{color:#fff;background:#16213e}.user-info{color:#ccc;font-size:.85rem}.role-badge{color:#64b5f6;text-transform:capitalize;background:#16213e;border-radius:3px;padding:.1rem .4rem;font-size:.7rem}.app-body{flex:1;display:flex;overflow:hidden}.sidebar{background:#1a1a2e;flex-direction:column;flex-shrink:0;width:220px;padding:.5rem 0;transition:width .2s;display:flex;overflow:hidden}.sidebar.collapsed{width:64px}.sidebar .nav-item{color:#ccc;white-space:nowrap;cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:.75rem;width:100%;padding:.6rem 1rem;font-size:.9rem;text-decoration:none;display:flex;position:relative}.sidebar .nav-item:hover{color:#64b5f6;background:#16213e}.sidebar .nav-item.active{color:#64b5f6;background:#16213e;border-right:3px solid #64b5f6}.sidebar .nav-icon{text-align:center;flex-shrink:0;width:24px;font-size:1.1rem}.sidebar .nav-label{transition:opacity .2s}.sidebar.collapsed .nav-label{opacity:0;width:0;overflow:hidden}.sidebar.collapsed .nav-item{justify-content:center;padding:.6rem 0}.sidebar.collapsed .nav-item:hover:after{content:attr(title);color:#fff;white-space:nowrap;z-index:20;pointer-events:none;background:#333;border-radius:4px;padding:.3rem .6rem;font-size:.8rem;position:absolute;left:64px}.sidebar-spacer{flex:1}.collapse-toggle{border-top:1px solid #333;margin-top:auto}.main-content{flex:1;height:calc(100vh - 52px);padding:1.5rem;overflow-y:auto}.page-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.page-header h2{font-size:1.4rem}table{border-collapse:collapse;background:#fff;border-radius:8px;width:100%;overflow:hidden;box-shadow:0 1px 3px #00000014}th,td{text-align:left;border-bottom:1px solid #eee;padding:.6rem .75rem;font-size:.9rem}th{color:#555;background:#f8f9fa;font-weight:600}tr:hover{background:#f5f8ff}button,.btn{cursor:pointer;border:none;border-radius:4px;padding:.4rem .8rem;font-size:.85rem}.btn-primary{color:#fff;background:#1a73e8}.btn-primary:hover{background:#1557b0}.btn-danger{color:#fff;background:#e53935}.btn-danger:hover{background:#c62828}.btn-secondary{color:#333;background:#e0e0e0}.btn-sm{padding:.25rem .5rem;font-size:.8rem}input,select{border:1px solid #ddd;border-radius:4px;padding:.5rem;font-size:.9rem}.filters{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:1rem;display:flex}.filters input,.filters select{min-width:140px}.badge{border-radius:12px;padding:.15rem .5rem;font-size:.75rem;font-weight:600;display:inline-block}.badge-active{color:#2e7d32;background:#e8f5e9}.badge-warning{color:#e65100;background:#fff3e0}.badge-inactive{color:#c62828;background:#fce4ec}.badge-skill{color:#1565c0;background:#e3f2fd}.badge-fte{color:#4527a0;background:#ede7f6}.badge-core{color:#2e7d32;background:#e8f5e9;margin-left:.25rem}.badge-support{color:#e65100;background:#fff3e0;margin-left:.25rem}.badge-requested{color:#8e24aa;background:#f3e5f5}.badge-sm{padding:.1rem .35rem;font-size:.65rem}.modal-overlay{z-index:100;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:8px;min-width:400px;max-width:90vw;max-height:90vh;padding:1.5rem;position:relative;overflow-y:auto}.modal h3{cursor:grab;-webkit-user-select:none;user-select:none;margin-bottom:1rem}.modal label{color:#555;margin-bottom:.25rem;font-size:.85rem;font-weight:600;display:block}.modal input,.modal select{width:100%;margin-bottom:.75rem}.modal input[type=checkbox],.modal input[type=radio]{width:auto;margin-bottom:0}.modal-actions{justify-content:flex-end;gap:.5rem;margin-top:1rem;display:flex}.success-msg{color:#2e7d32;background:#e8f5e9;border-radius:4px;margin-bottom:.75rem;padding:.5rem;font-size:.9rem}.board-layout{gap:1rem;height:calc(100vh - 120px);display:flex}.resource-pane{background:#fff;border-radius:8px;flex-shrink:0;width:280px;padding:.75rem;overflow-y:auto;box-shadow:0 1px 3px #00000014}.resource-pane h3{margin-bottom:.5rem;font-size:1rem}.squad-area{flex:1;overflow-y:auto}.squad-grid{flex:1;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));align-content:start;gap:.5rem;display:grid;overflow-y:auto}.squad-card{background:#fff;border:2px solid #0000;border-radius:8px;margin-bottom:.5rem;transition:border-color .15s;box-shadow:0 1px 3px #00000014}.squad-card.squad-drop-over{background:#f5f8ff;border-color:#1a73e8}.squad-header{cursor:pointer;border-radius:8px;justify-content:space-between;align-items:center;padding:.75rem;font-weight:600;display:flex}.squad-header:hover{background:#f5f8ff}.squad-body{padding:0 .75rem .75rem}.squad-body.grid-body{max-height:350px;overflow-y:auto}.alloc-item{border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:center;padding:.4rem .5rem;font-size:.85rem;display:flex}.alloc-item:last-child{border-bottom:none}.fte-input{text-align:center;width:70px}.drop-hint{color:#aaa;text-align:center;padding:.25rem;font-size:.8rem}.layout-toggle{gap:2px;display:flex}.resource-card{cursor:grab;border:1px solid #e0e0e0;border-radius:4px;justify-content:space-between;align-items:center;margin-bottom:.25rem;padding:.5rem;font-size:.85rem;display:flex;position:relative}.resource-card:hover{background:#f5f8ff}.resource-card.disabled{opacity:.5;cursor:not-allowed;background:#f5f5f5}.resource-card.non-active{border-left:3px solid #ff9800}.resource-card.requested{background:#f3e5f5;border:1px dashed #8e24aa}.alloc-item.alloc-non-active{border-left:3px solid #ff9800}.alloc-item.alloc-requested{background:#faf5fc;border-left:3px dashed #8e24aa}.btn-toggle-type{cursor:pointer;border:none;margin-left:.25rem}.btn-request{color:#8e24aa;background:#f3e5f5;border:1px dashed #8e24aa;width:100%;margin-top:.25rem}.btn-request:hover{background:#e1bee7}.btn-clear{color:#999;cursor:pointer;background:0 0;border:none;border-radius:2px;padding:0 .2rem;font-size:1rem;line-height:1}.btn-clear:hover{color:#e53935;background:#fce4ec}.resource-card .tooltip{color:#fff;white-space:nowrap;z-index:10;background:#333;border-radius:4px;padding:.4rem .6rem;font-size:.75rem;display:none;position:absolute;bottom:100%;left:0}.resource-card:hover .tooltip{display:block}.board-toolbar{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:1rem;display:flex}.board-toolbar select{min-width:180px}.board-name-input{border:1px solid #1a73e8;border-radius:4px;outline:none;padding:.1rem .4rem;font-size:1.4rem;font-weight:700}.report-section{background:#fff;border-radius:8px;margin-bottom:1rem;padding:1rem;box-shadow:0 1px 3px #00000014}.report-tabs{border-bottom:2px solid #e0e0e0;gap:0;margin-bottom:1rem;display:flex}.report-tab{cursor:pointer;color:#666;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:.5rem 1rem;font-size:.9rem}.report-tab:hover{color:#1a73e8}.report-tab.active{color:#1a73e8;border-bottom-color:#1a73e8;font-weight:600}.compare-selectors{background:#fff;border-radius:8px;flex-wrap:wrap;align-items:flex-end;gap:1rem;margin-bottom:1rem;padding:1rem;display:flex;box-shadow:0 1px 3px #00000014}.compare-side{flex-direction:column;gap:.5rem;display:flex}.compare-side h4{color:#555;margin:0;font-size:.9rem}.compare-side select{min-width:200px}.compare-summary{background:#fff;border-radius:8px;flex-direction:column;gap:.5rem;margin-bottom:1rem;padding:1rem;display:flex;box-shadow:0 1px 3px #00000014}.compare-legend{gap:.75rem;margin-top:.25rem;font-size:.8rem;display:flex}.compare-results{flex-direction:column;gap:.5rem;display:flex}.squad-config{background:#fafafa;border-top:1px solid #eee;padding:.5rem .75rem;overflow:hidden}.squad-config select{min-width:0}.board-loading{z-index:5;background:#ffffffb3;border-radius:8px;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.board-loading span{color:#fff;background:#1a73e8;border-radius:4px;padding:.4rem 1rem;font-size:.85rem;animation:.8s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.squad-saving{opacity:.6;pointer-events:none}.squad-saving-bar{color:#fff;text-align:center;background:#1a73e8;border-radius:8px 8px 0 0;padding:.15rem;font-size:.75rem;animation:.8s ease-in-out infinite pulse}.import-section{background:#fff;border-radius:8px;margin-bottom:1rem;padding:1.5rem;box-shadow:0 1px 3px #00000014}.import-section h3{margin-bottom:.75rem}.import-result{background:#f5f5f5;border-radius:4px;margin-top:.75rem;padding:.75rem;font-size:.9rem}.checkbox-list{max-height:300px;overflow-y:auto}.checkbox-list label{cursor:pointer;align-items:center;gap:.5rem;padding:.25rem 0;font-size:.9rem;display:flex}.info-id{cursor:pointer;vertical-align:middle;align-items:center;margin-left:.25rem;display:inline-flex;position:relative}.info-icon{color:#1565c0;background:#e3f2fd;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;font-size:.7rem;font-style:normal;display:inline-flex}.info-id:hover .info-icon{color:#fff;background:#1565c0}.info-tooltip{color:#fff;white-space:nowrap;z-index:20;background:#333;border-radius:4px;margin-bottom:4px;padding:.3rem .6rem;font-family:monospace;font-size:.75rem;display:none;position:absolute;bottom:100%;left:50%;transform:translate(-50%)}.info-id:hover .info-tooltip{display:block}.fab-refresh{color:#fff;cursor:pointer;z-index:50;background:#1a73e8;border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.3rem;display:flex;position:fixed;bottom:1.5rem;right:1.5rem;box-shadow:0 2px 8px #0003}.fab-refresh:hover{background:#1557b0}@media (width<=768px){.top-bar{padding:0 .5rem}.brand{font-size:.95rem}.user-info{display:none}.main-content{padding:.75rem}.board-layout{flex-direction:column;height:auto}.resource-pane{width:100%;max-height:300px}.filters{flex-direction:column}.modal{width:95vw;min-width:auto}}.resource-card.excluded{opacity:.5;cursor:not-allowed;background:#f8f9fa;border-left:3px solid #dc3545;text-decoration:line-through}.resource-card.excluded:hover{opacity:.7}.context-menu{background:#fff;border:1px solid #ddd;border-radius:6px;min-width:200px;padding:4px 0;box-shadow:0 4px 12px #00000026}.context-menu-item{cursor:pointer;padding:8px 16px;font-size:.875rem}.context-menu-item:hover{background:#f0f0f0}
