*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;overflow:hidden}body{font-family:DM Sans,system-ui,sans-serif;background:#f4f6fa;color:#1a1a1a}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#b0bec5;border-radius:99px}input,textarea,select{font-family:DM Sans,system-ui,sans-serif;outline:none}button{font-family:DM Sans,system-ui,sans-serif;cursor:pointer}.app{display:flex;height:100vh;overflow:hidden}.sidebar{width:220px;min-width:220px;background:#0d2b4e;display:flex;flex-direction:column;height:100vh;overflow:hidden}.sidebar-logo{padding:18px 16px 12px;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-logo-mark{display:flex;align-items:center;gap:8px}.logo-badge{width:30px;height:30px;border-radius:8px;background:#1b75bc;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;flex-shrink:0}.logo-text{font-size:15px;font-weight:700;color:#fff;letter-spacing:-.3px}.logo-sub{font-size:10px;color:#ffffff73;letter-spacing:.5px;text-transform:uppercase;margin-top:1px}.project-selector{margin:10px 10px 0;background:#1b75bc2e;border-radius:8px;padding:8px 10px;border:1px solid rgba(27,117,188,.35)}.project-name-label{font-size:11px;font-weight:600;color:#ffffff80;text-transform:uppercase;letter-spacing:.5px}.project-label{font-size:13px;color:#fff;font-weight:500;margin-top:2px;display:flex;align-items:center;justify-content:space-between}.project-dot{width:7px;height:7px;border-radius:50%;background:#f58229;flex-shrink:0}.nav-section{padding:14px 8px 4px;flex:1;overflow-y:auto}.nav-group-label{font-size:9.5px;font-weight:600;color:#ffffff4d;letter-spacing:.8px;text-transform:uppercase;padding:0 8px;margin-bottom:4px;margin-top:4px}.nav-item{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:7px;cursor:pointer;color:#ffffff8c;font-size:13px;font-weight:500;transition:all .15s;margin-bottom:2px;border:none;background:transparent;width:100%;text-align:left}.nav-item:hover{background:#1b75bc33;color:#ffffffe6}.nav-item.active{background:#f5822926;color:#fff;border-left:3px solid #F58229;padding-left:7px}.nav-item.active .nav-icon{color:#f58229}.nav-icon{font-size:16px;width:18px;text-align:center;flex-shrink:0}.nav-badge{margin-left:auto;background:#f58229;color:#fff;font-size:9px;font-weight:700;padding:1px 5px;border-radius:99px}.sidebar-footer{padding:10px;border-top:1px solid rgba(255,255,255,.08)}.user-pill{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:7px}.avatar{width:28px;height:28px;border-radius:50%;background:#1b75bc;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0}.user-info{flex:1}.user-name-text{font-size:12px;color:#fff;font-weight:500}.user-role-text{font-size:10px;color:#fff6}.main{flex:1;display:flex;flex-direction:column;overflow:hidden}.topbar{height:52px;background:#fff;border-bottom:2px solid #1B75BC;display:flex;align-items:center;padding:0 20px;gap:12px;flex-shrink:0}.topbar-title{font-size:15px;font-weight:700;color:#0d2b4e}.topbar-sub{font-size:12px;color:#58595b;margin-left:4px}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:8px}.content{flex:1;overflow-y:auto;padding:20px}.btn{padding:6px 14px;border-radius:7px;font-size:12px;font-weight:600;cursor:pointer;border:none;transition:all .15s;display:inline-flex;align-items:center;gap:5px}.btn-primary{background:#f58229;color:#fff}.btn-primary:hover{background:#d96f1e}.btn-ghost{background:#f1f5f9;color:#58595b;border:1px solid #D0D7DE}.btn-ghost:hover{background:#e2e8f0}.btn-blue{background:#1b75bc;color:#fff}.btn-blue:hover{background:#155f9a}.card{background:#fff;border-radius:10px;border:1px solid #D8E4EF;padding:16px}.card-sm{padding:12px 16px}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.card-title{font-size:13px;font-weight:700;color:#0d2b4e;display:flex;align-items:center;gap:6px}.card-meta{font-size:11px;color:#58595b}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:16px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:16px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:16px}.grid-3-2{display:grid;grid-template-columns:3fr 2fr;gap:14px;margin-bottom:16px}.kpi-card{background:#fff;border-radius:10px;border:1px solid #D8E4EF;border-left:4px solid #1B75BC;padding:16px;position:relative;overflow:hidden}.kpi-label{font-size:11px;font-weight:600;color:#58595b;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.kpi-value{font-size:28px;font-weight:800;color:#0d2b4e;letter-spacing:-1.5px;line-height:1}.kpi-sub{font-size:11px;color:#58595b;margin-top:5px}.kpi-icon{position:absolute;top:14px;right:14px;width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:18px}.kpi-trend{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:600;padding:2px 7px;border-radius:99px;margin-top:6px}.trend-up{background:#e8f5e9;color:#2e7d32}.trend-down{background:#ffebee;color:#c62828}.trend-warn{background:#fff8e1;color:#e65100}.badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:99px;font-size:11px;font-weight:600;gap:4px;white-space:nowrap}.badge-blue{background:#e3f0fa;color:#1b75bc}.badge-green{background:#e8f5e9;color:#2e7d32}.badge-red{background:#ffebee;color:#c62828}.badge-yellow{background:#fff8e1;color:#e65100}.badge-purple{background:#ede7f6;color:#6a1b9a}.badge-gray{background:#eceff1;color:#546e7a}.badge-orange{background:#fef0e4;color:#e65100}.badge-action{background:#f58229;color:#fff}.dot{width:7px;height:7px;border-radius:50%;display:inline-block;flex-shrink:0}.dot-green{background:#43a047}.dot-blue{background:#1b75bc}.dot-red{background:#e53935}.dot-yellow{background:#fb8c00}.dot-gray{background:#78909c}.dot-orange{background:#f58229}.progress-wrap{height:6px;background:#e3eef7;border-radius:99px;overflow:hidden}.progress-fill{height:100%;border-radius:99px;transition:width .3s}.ms-timeline{display:flex;align-items:flex-start;position:relative;padding:20px 10px 10px}.ms-timeline:before{content:"";position:absolute;top:26px;left:10px;right:10px;height:2px;background:#d8e4ef}.ms-item{flex:1;display:flex;flex-direction:column;align-items:center;position:relative}.ms-dot{width:14px;height:14px;border-radius:50%;border:3px solid #D8E4EF;background:#fff;z-index:1;margin-bottom:8px}.ms-dot.done{background:#1b75bc;border-color:#1b75bc}.ms-dot.active{background:#f58229;border-color:#f58229;box-shadow:0 0 0 3px #f5822933}.ms-dot.upcoming{background:#fff;border-color:#1b75bc}.ms-name{font-size:10px;font-weight:600;color:#0d2b4e;text-align:center;line-height:1.2;max-width:70px}.ms-date{font-size:9.5px;color:#58595b;text-align:center;margin-top:2px}.phase-row{display:flex;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid #F0F4FA}.phase-row:last-child{border-bottom:none}.phase-name-col{font-size:12px;font-weight:600;color:#0d2b4e;width:120px;flex-shrink:0}.phase-bar{flex:1;height:8px;background:#e3eef7;border-radius:99px;overflow:hidden}.phase-fill{height:100%;border-radius:99px;transition:width .4s}.phase-pct{font-size:11px;font-weight:700;color:#0d2b4e;width:35px;text-align:right}.phase-st{font-size:10px;color:#58595b;width:65px;text-align:right;flex-shrink:0}.table{width:100%;border-collapse:collapse;font-size:12.5px}.table th{text-align:left;font-size:11px;font-weight:700;color:#1b75bc;text-transform:uppercase;letter-spacing:.4px;padding:9px 10px;border-bottom:2px solid #1B75BC;background:#f4f8fc;white-space:nowrap}.table td{padding:10px;border-bottom:1px solid #EEF2F7;vertical-align:middle}.table tr:last-child td{border-bottom:none}.table tbody tr:hover td{background:#f4f8fc}.heatmap{display:grid;grid-template-columns:20px repeat(5,1fr);grid-template-rows:repeat(5,1fr) 20px;gap:3px;font-size:9px}.hm-cell{border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#0009;min-height:28px}.hm-label{display:flex;align-items:center;justify-content:center;font-size:9px;color:#58595b;font-weight:500}.kanban-board{display:flex;gap:12px;overflow-x:auto;padding-bottom:16px;align-items:flex-start}.kanban-col{min-width:195px;width:195px;flex-shrink:0;display:flex;flex-direction:column;gap:8px}.kanban-col-header{display:flex;align-items:center;justify-content:space-between;padding:7px 10px;border-radius:8px;font-size:12px;font-weight:700}.kanban-card{background:#fff;border-radius:9px;border:1px solid #D8E4EF;padding:10px 11px;cursor:pointer;transition:all .15s}.kanban-card:hover{box-shadow:0 3px 10px #1b75bc1f;border-color:#1b75bc;transform:translateY(-1px)}.kanban-card-title{font-size:12px;font-weight:600;color:#0d2b4e;line-height:1.3;margin-bottom:8px}.kanban-card-meta{display:flex;align-items:center;justify-content:space-between}.kanban-tag{font-size:10px;color:#58595b;background:#f4f8fc;padding:2px 7px;border-radius:99px;border:1px solid #D8E4EF}.kanban-assignee{width:20px;height:20px;border-radius:50%;background:#1b75bc;display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:700;color:#fff;flex-shrink:0}.gantt-wrap{overflow:auto;border:1px solid #D8E4EF;border-radius:10px;background:#fff}.gantt-row{display:flex;border-bottom:1px solid #EEF2F7;min-height:34px;align-items:center}.gantt-row:hover{background:#f4f8fc}.gantt-row.phase-header-row{background:#eaf2fb;min-height:30px}.gantt-label{width:230px;min-width:230px;padding:6px 12px;font-size:12px;border-right:1px solid #D8E4EF;display:flex;align-items:center;gap:7px;overflow:hidden}.gantt-bars{flex:1;position:relative;height:100%;min-width:600px}.gantt-bar{position:absolute;height:18px;border-radius:4px;top:50%;transform:translateY(-50%)}.raci-wrap{overflow:auto}.raci-table{border-collapse:collapse;width:100%;font-size:12px}.raci-table th{padding:9px 12px;background:#eaf2fb;border:1px solid #D8E4EF;font-size:10.5px;font-weight:700;color:#1b75bc;white-space:nowrap}.raci-table td{padding:9px 12px;border:1px solid #EEF2F7;text-align:center;font-weight:700;font-size:12px;cursor:pointer;transition:background .1s}.raci-table td.activity-cell{text-align:left;font-weight:500;font-size:12px;color:#0d2b4e;white-space:nowrap;cursor:default;background:#f4f8fc}.raci-table tr:hover td,.raci-table tr:hover td.activity-cell{background:#f0f7ff}.raci-r{color:#1b75bc;background:#e3f0fa}.raci-a{color:#c45c0a;background:#fef0e4}.raci-c{color:#2e7d32;background:#e8f5e9}.raci-i{color:#546e7a;background:#eceff1}.issue-row{display:flex;align-items:center;gap:10px;padding:11px 12px;border-bottom:1px solid #EEF2F7;transition:background .1s;font-size:12.5px}.issue-row:hover{background:#f4f8fc}.issue-title{flex:1;font-weight:500;color:#0d2b4e}.chip{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:7px;font-size:11px;font-weight:600;background:#f4f8fc;color:#1b75bc;cursor:pointer;border:1px solid #D8E4EF}.chip:hover{background:#e3eef7;border-color:#1b75bc}.form-label{font-size:11px;font-weight:600;color:#58595b;display:block;margin-bottom:4px;text-transform:uppercase;letter-spacing:.4px}.form-input{width:100%;padding:8px 11px;border:1.5px solid #D8E4EF;border-radius:7px;font-size:13px;color:#0d2b4e;background:#fff}.form-input:focus{border-color:#1b75bc;box-shadow:0 0 0 3px #1b75bc1f}.form-textarea{width:100%;padding:8px 11px;border:1.5px solid #D8E4EF;border-radius:7px;font-size:13px;color:#0d2b4e;resize:none;background:#fff}.form-textarea:focus{border-color:#1b75bc;box-shadow:0 0 0 3px #1b75bc1f}select.form-input{cursor:pointer}.section-divider{height:2px;background:linear-gradient(90deg,#1B75BC,transparent);margin:4px 0 14px;border-radius:99px}@media (max-width:900px){.sidebar{width:60px;min-width:60px}.logo-text,.logo-sub,.project-selector,.nav-group-label,.nav-item span,.user-info{display:none}.nav-item{justify-content:center;padding:10px}.nav-icon{width:auto}.grid-4{grid-template-columns:repeat(2,1fr)}.grid-3-2,.grid-2{grid-template-columns:1fr}}
