:root{color:#172033;background:#f5f7fb}*{box-sizing:border-box}body{margin:0;min-width:360px}button{font:inherit}.app-frame{display:flex;min-height:100vh;background:#f5f7fb}.brand{display:flex;align-items:center;padding:28px 22px 22px}.brand-mark{background:#0b5cad}.brand-logo{width:210px;max-width:100%;height:auto;object-fit:contain;flex:0 0 auto}.auth-logo{width:220px;max-width:100%;height:auto;object-fit:contain}.nav-list{flex:1;padding:12px 14px}.nav-footer{display:flex;flex-direction:column;gap:8px;padding:18px 24px 24px;border-top:1px solid #e6eaf2}.auth-screen{display:flex;min-height:100vh;align-items:center;justify-content:center;padding:32px;background:#f5f7fb}.auth-panel{width:min(100%,460px);display:flex;flex-direction:column;gap:18px;align-items:flex-start;padding:32px;border:1px solid #e4e8f1;border-radius:8px;background:#fff;box-shadow:0 18px 48px #0f172a14}.team-form{width:100%;display:flex;flex-direction:column;gap:16px}.nav-item{gap:16px;border-radius:8px;cursor:pointer;color:#334155}.nav-item .MuiListItemIcon-root,.sub-nav-item .MuiListItemIcon-root{min-width:0;color:inherit}.nav-item.active{color:#0b5cad;background:#eef4ff}.sub-nav-list{padding:10px 0 8px}.sub-nav-list .MuiListItemButton-root.sub-nav-item{position:relative;gap:14px;min-height:48px;width:calc(100% - 42px);margin-top:6px;margin-left:42px;padding-left:18px!important;border-radius:8px;color:#526071}.sub-nav-list .MuiListItemButton-root.sub-nav-item .MuiListItemIcon-root{margin-left:0}.sub-nav-list .MuiListItemButton-root.sub-nav-item.active{color:#0b5cad;background:transparent;font-weight:800}.sub-nav-list .MuiListItemButton-root.sub-nav-item.active:before{content:"";position:absolute;left:-18px;top:50%;width:3px;height:28px;border-radius:999px;background:#0b5cad;transform:translateY(-50%)}.main{flex:1;min-width:0}.topbar{border-bottom:1px solid #e6eaf2;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#f5f7fbe0}.toolbar{gap:14px;justify-content:space-between;min-height:78px}.topbar-organization{max-width:320px;overflow:hidden;color:#334155;font-weight:700;text-align:right;text-overflow:ellipsis;white-space:nowrap}.content-band{padding:28px 32px 40px}.timeline-actions{margin-bottom:22px}.range-controls{flex-wrap:wrap}.range-select{min-width:180px;background:#fff}.timeline-shell{overflow:auto;border:1px solid #e4e8f1;border-radius:8px;background:#fff}.timeline-grid{position:relative;display:grid}.today-line{position:absolute;top:0;bottom:0;z-index:6;width:1px;background:#dc2626;pointer-events:none}.timeline-month-corner{position:sticky;left:0;z-index:5;height:34px;border-bottom:1px solid #e4e8f1;background:#f8fafc}.timeline-months{display:flex;height:34px;border-bottom:1px solid #e4e8f1;background:#f8fafc}.timeline-month{display:flex;align-items:center;padding:0 14px;border-left:1px solid #e4e8f1;color:#526071;font-size:.82rem;font-weight:800;text-transform:uppercase;white-space:nowrap}.timeline-head{height:64px;display:flex;align-items:center;border-bottom:1px solid #e4e8f1;background:#f0f4fa}.employees-head{position:sticky;left:0;z-index:4;padding:0 22px;color:#253247;font-size:.82rem;font-weight:800;text-transform:uppercase}.day-head{justify-content:center;flex-direction:column;border-left:1px solid #e4e8f1}.day-head.weekend{background:#e7ebf2;color:#526071}.timeline-section-label{position:sticky;left:0;z-index:3;display:flex;align-items:center;height:38px;padding:0 12px;border-bottom:1px solid #e4e8f1;background:#f8fafc;color:#253247;font-size:.78rem;font-weight:800;text-transform:uppercase}.section-toggle{color:inherit;font-size:.78rem;font-weight:800;letter-spacing:0;text-transform:uppercase}.timeline-section-area{display:grid;height:38px;border-bottom:1px solid #e4e8f1;background:#f8fafc}.employee-team-label{height:32px;background:#fff;color:#0b5cad;text-transform:none}.employee-team-label .MuiTypography-root{font-weight:800}.employee-team-area{height:32px;background:#fff}.employee-row,.project-row{display:contents}.project-cell{position:sticky;left:0;z-index:3;display:flex;gap:14px;align-items:flex-start;min-height:72px;padding:16px 18px;border-bottom:1px solid #edf0f6;background:#fff}.employee-cell{position:sticky;left:0;z-index:3;display:flex;gap:14px;align-items:flex-start;padding:22px 18px;border-bottom:1px solid #edf0f6;background:#fff}.employee-cell.clickable{cursor:pointer}.employee-cell.clickable:hover{background:#f8fafc}.employee-avatar{background:#e8edf7;color:#253247;font-weight:800}.assignment-area{position:relative;display:grid;border-bottom:1px solid #edf0f6;background:#fbfcff}.project-area{min-height:72px}.day-line{border-left:1px solid #edf0f6}.day-line.weekend{background:#eef1f6}.assignment-bar{position:absolute;height:28px;border:0;border-left:4px solid rgba(255,255,255,.65);border-radius:0;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:0 14px;color:#fff;box-shadow:0 6px 16px #0f172a1f;cursor:grab;overflow:hidden;touch-action:none;-webkit-user-select:none;user-select:none}.project-bar{position:absolute;top:22px;height:28px;border:0;border-left:4px solid rgba(255,255,255,.65);border-radius:0;display:flex;align-items:center;padding:0 14px;color:#fff;box-shadow:0 6px 16px #0f172a1f;cursor:grab;overflow:hidden;touch-action:none;-webkit-user-select:none;user-select:none}.assignment-bar:active,.project-bar:active{cursor:grabbing}.project-marker{position:absolute;top:17px;z-index:2;width:26px;height:26px;padding:0;border:2px solid #ffffff;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 12px #0f172a33;cursor:grab;transform:translate(-50%);pointer-events:auto;touch-action:none;-webkit-user-select:none;user-select:none}.project-marker:active{cursor:grabbing}.assignment-handle{position:absolute;top:0;width:10px;height:100%;background:#ffffff38;cursor:ew-resize}.assignment-handle.left{left:0}.assignment-handle.right{right:0}.assignment-bar span,.assignment-bar strong,.project-bar span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-layout{display:grid;grid-template-columns:repeat(2,minmax(280px,1fr));gap:24px;padding:32px}.admin-layout.single{grid-template-columns:minmax(280px,1fr)}.admin-panel{border:1px solid #e4e8f1;border-radius:8px;padding:22px;background:#fff}.color-swatch{width:36px;height:36px;border:2px solid transparent;border-radius:50%;cursor:pointer}.color-swatch.active{border-color:#101828;outline:3px solid #dbeafe}.danger-button,.danger-icon{color:#dc2626}.danger-button:hover{background:#dc262614}.icon-picker{display:grid;grid-template-columns:repeat(auto-fill,minmax(118px,1fr));gap:8px;max-height:220px;overflow:auto;padding:8px;border:1px solid #e4e8f1;border-radius:8px;background:#f8fafc}.icon-picker.disabled{opacity:.58}.icon-picker-button{min-width:0;height:34px;border:1px solid #e4e8f1;border-radius:6px;display:flex;align-items:center;gap:8px;padding:0 10px;background:#fff;color:#334155;cursor:pointer}.icon-picker-button span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.icon-picker-button.active{border-color:#0b5cad;color:#0b5cad;background:#eef4ff}.icon-picker-button:disabled{cursor:default}.marker-settings-grid{align-items:stretch}.marker-setting-card{flex:1;min-width:240px}@media (max-width: 900px){.MuiDrawer-root{display:none}.toolbar{flex-wrap:wrap;height:auto;padding:14px}.content-band,.admin-layout{padding:18px}.timeline-actions{align-items:flex-start;flex-direction:column;gap:16px}.admin-layout{grid-template-columns:1fr}}
