html,body,#root{width:100%;min-width:100%;height:100%;margin:0;padding:0}body{overflow:hidden}html,body,#root{width:100%;height:100%;margin:0;padding:0}body{background:#f5f6fa;font-family:Arial,sans-serif;overflow:hidden}.app{box-sizing:border-box;background:#f5f6fa;width:100%;height:100vh;padding:10px}h1{text-align:center;margin:0 0 8px;font-size:20px}.toolbar{flex-wrap:wrap;align-items:center;gap:8px;padding:0 10px;display:flex}.toolbar button,.toolbar input{cursor:pointer;background:#fff;border:1px solid #aaa;border-radius:8px;height:28px;padding:0 8px;font-size:12px}.toolbar button,.toolbar input[type=date]{box-sizing:border-box;height:28px}.toolbar input[type=date]{appearance:none}.active-range{font-weight:700;color:#fff!important;background:#374151!important;border-color:#374151!important}.stats{gap:8px;margin-left:auto;display:flex}.stats span{background:#fff;border:1px solid #ccc;padding:7px 10px;font-size:12px}.planner{background:#fff;border:1px solid #aaa;width:100%;height:calc(100vh - 128px);overflow:auto}.planner-inner{align-items:flex-start;min-width:max-content;display:flex}.info-panel{z-index:30;background:#fff;border-right:2px solid #777;width:655px;min-width:655px;position:sticky;left:0}.info-panel.compact{width:415px;min-width:415px}.table-title{box-sizing:border-box;background:#d9d9d9;border-bottom:1px solid #999;justify-content:center;align-items:center;height:30px;font-weight:700;display:flex}.info-header{box-sizing:border-box;background:#eee;border-bottom:1px solid #aaa;grid-template-columns:100px 55px minmax(180px,1fr) 130px 110px 55px 25px;height:30px;font-size:11px;display:grid}.info-sticky-header{z-index:60;background:#fff;position:sticky;top:0}.info-panel.compact .info-header{grid-template-columns:100px 55px minmax(180px,1fr) 55px 25px}.info-header div{border-right:1px solid #ccc;justify-content:center;align-items:center;display:flex}.project-cell{box-sizing:border-box;background:#fff;border-bottom:1px solid #ddd;border-right:1px solid #ddd;flex-shrink:0;justify-content:space-between;align-items:center;width:100px;padding:0 4px;display:flex}.project-cell input{box-sizing:border-box;border:0;flex:1;min-width:0;height:100%;padding:0 4px;font-size:11px}.add-task-btn{cursor:pointer;background:#f3f4f6;border:1px solid #ccc;border-radius:4px;flex-shrink:0;width:18px;height:18px;padding:0;font-size:11px;line-height:1}.project-task-list{flex-direction:column;display:flex}.task-row-fields{box-sizing:border-box;border-bottom:1px solid #ddd;grid-template-columns:55px minmax(180px,1fr) 130px 110px 55px 25px;height:30px;display:grid}.info-panel.compact .task-row-fields{grid-template-columns:55px minmax(180px,1fr) 55px 25px}.task-row-fields input{box-sizing:border-box;background:#fff;border:0;border-right:1px solid #ddd;width:100%;height:100%;padding:0 8px;font-size:11px}.task-row-fields input:focus{z-index:2;outline:1px solid #3b82f6}.task-highlight,.task-highlight input,.task-highlight .doc-cell,.task-highlight .status-cell{animation:2s taskBlink}@keyframes taskBlink{0%{background-color:#fff7a8}25%{background-color:#ffe766}50%{background-color:#fff7a8}75%{background-color:#ffe766}to{background-color:#0000}}.doc-cell{grid-template-columns:1fr 28px;height:100%;display:grid}.doc-cell input{border:0;border-right:1px solid #ddd;padding:0 8px}.doc-cell.linked input{background:#dbeafe}.doc-cell.linked .url-button{color:#2563eb;background:#dbeafe;font-weight:700}.url-button{cursor:pointer;background:#f3f4f6;border:0;border-right:1px solid #ddd;font-size:9px}.url-button.linked{color:#2563eb;background:#dbeafe;font-weight:700}.url-input-row input{flex:1}.open-url-btn{cursor:pointer;flex-shrink:0;width:40px;height:40px}.timeline-header{box-sizing:border-box;z-index:25;background:#fafafa;border-bottom:1px solid #999;height:60px;position:sticky;top:0}.planner,.timeline-panel{overscroll-behavior:contain}.month-row,.week-row,.date-row{box-sizing:border-box;height:20px;display:flex}.month-cell,.week-cell,.day-cell{box-sizing:border-box;-webkit-user-select:none;user-select:none;border-bottom:1px solid #9a9a9a;border-right:1px solid #9a9a9a;justify-content:center;align-items:center;min-width:32px;height:20px;font-size:10px;line-height:1;display:flex}.month-cell{background:#f3f4f6;font-weight:600}.week-cell{background:#fafafa;font-weight:500}.day-cell{background:#fff;font-weight:400}.day-cell.today{color:#d00000;background:#fff3bf;font-weight:700}.timeline-row{box-sizing:border-box;border-bottom:1px solid #ddd;height:30px;display:flex}.day-cell.last-friday{color:#dc2626;background:#fee2e2;font-weight:700}.grid-cell{box-sizing:border-box;cursor:crosshair;border-right:1px solid #d6d6d6;min-width:32px;height:30px}.planner.locked .grid-cell{cursor:not-allowed}.grid-cell:hover{background:#eff6ff}.grid-cell.selected{background:#3b82f6;border-bottom:1px solid #d6d6d6;border-right:1px solid #d6d6d6}.timeline-row.project-bottom-line .grid-cell.selected{border-bottom:2px solid #999}.grid-cell.selected:hover{background:#2563eb}.grid-cell.today-line{background:#fff8dc}.grid-cell.selected.today-line{background:#2563eb}.status-cell{box-sizing:border-box;background:#fff;border-right:1px solid #ddd;justify-content:center;align-items:center;height:100%;display:flex}.status-pill{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:999px;justify-content:center;align-items:center;height:22px;padding:0 10px;font-size:10px;font-weight:500;line-height:1;transition:all .15s;display:inline-flex}.status-pill:hover{transform:scale(1.2)}.status-완료{color:#1d4ed8;background:#dbeafe}.status-진행{color:#15803d;background:#dcfce7}.status-대기{color:#4b5563;background:#f3f4f6}.delete-btn{color:#818181;cursor:pointer;background:#f8fafc;border:0;border-right:1px solid #ddd;width:100%;height:100%;font-size:12px;font-weight:200}.delete-btn:hover{color:#dc2626;background:#fee2e2}.day-cell.custom-holiday{color:#dc2626;background:#fee2e2;font-weight:700}.grid-cell.custom-holiday-line{background:#fff1f2}.grid-cell.selected.custom-holiday-line{background:#2563eb}.modal-backdrop{z-index:100;background:#00000040;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.url-modal{background:#fff;border-radius:18px;width:460px;padding:22px;box-shadow:0 20px 60px #0f172a47}.url-modal h3{margin:0 0 14px;font-size:20px}.url-input-row{align-items:center;gap:8px;display:flex}.url-input-row input{box-sizing:border-box;border:1px solid #d1d5db;border-radius:12px;outline:none;flex:1;height:42px;padding:0 12px;font-size:14px}.url-input-row input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.open-url-btn{color:#2563eb;cursor:pointer;background:#eff6ff;border:0;border-radius:12px;width:42px;height:42px;font-size:16px}.modal-actions{justify-content:flex-end;gap:8px;margin-top:16px;display:flex}.modal-actions button{cursor:pointer;color:#374151;background:#f3f4f6;border:0;border-radius:999px;height:36px;padding:0 16px;font-weight:700}.modal-actions button:first-child{color:#fff;background:#2563eb}.modal-actions button:nth-child(3){color:#dc2626;background:#fee2e2}.grid-cell.last-friday-line{background:#fff1f2}.grid-cell.selected.last-friday-line{background:#3b82f6}.red-selected{background:#ef4444}.red-selected:hover{background:#dc2626}.task-row-fields,.timeline-row,.project-cell{box-sizing:border-box}.project-group{align-items:stretch;display:flex}.project-cell.project-bottom-line,.task-row-fields.project-bottom-line{border-bottom:2px solid #999!important}.timeline-row.project-bottom-line{border-bottom:0}.timeline-row.project-bottom-line .grid-cell{border-bottom:2px solid #999}.topbar{z-index:50;background:#f5f6fa;height:98px;margin-bottom:10px;position:sticky;top:0}.header-row{align-items:center;height:48px;display:flex;position:relative}.page-tabs{z-index:2;gap:5px;margin-left:10px;display:flex}.page-tabs button{cursor:pointer;background:#fff;border:1px solid #aaa;border-radius:999px;width:110px;height:36px;font-size:13px;transition:all .15s}.page-tabs button.active{color:#fff;background:#374151;border-color:#374151;border-radius:999px;font-weight:700}.header-row h1{white-space:nowrap;margin:0;font-size:28px;font-weight:700;position:absolute;left:50%;transform:translate(-50%)}.toolbar{flex-wrap:wrap;align-items:center;gap:8px;height:50px;display:flex}.dashboard{box-sizing:border-box;background:#f5f6fa;width:100%;height:calc(100vh - 128px);padding:0 16px 16px;overflow:auto}.dashboard-cards{grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:16px;display:grid}.dashboard-card.simple{justify-content:space-between;align-items:center;display:flex}.dashboard-card.simple span{font-size:18px;font-weight:600}.dashboard-card{box-sizing:border-box;background:#fff;border:1px solid #ddd;border-radius:8px;height:80px;padding:16px}.dashboard-card p{margin:0 0 8px;font-size:14px}.dashboard-card.simple strong{font-size:22px;font-weight:700}.dashboard-grid{grid-template-columns:repeat(4,1fr);align-items:stretch;gap:12px;display:grid}.dashboard-panel{box-sizing:border-box;background:#fff;border:1px solid #ddd;border-radius:8px;min-height:200px;padding:16px}.dashboard-panel h3{margin:0 0 16px}.donut-row{justify-content:center;align-items:center;gap:20px;height:150px;display:flex}.donut{border-radius:50%;width:120px;height:120px;position:relative}.donut:after{content:"";background:#fff;border-radius:50%;position:absolute;inset:35px}.project-donut{background:conic-gradient(#3b82f6 0 35%, #84cc16 35% 65%, #f59e0b 65% 85%, #8b5cf6 85% 100%)}.status-donut{background:conic-gradient(#3b82f6 0 40%, #f59e0b 40% 65%, #84cc16 65% 100%)}.dashboard-legend div{align-items:center;gap:8px;margin-bottom:10px;font-size:12px;display:flex}.legend-dot{background:#3b82f6;border-radius:50%;width:10px;height:10px}.legend-dot.orange{background:#f59e0b}.legend-dot.green{background:#84cc16}.project-donut.empty{background:conic-gradient(#3b82f6 0 100%)!important}.owner-bars{flex-direction:column;justify-content:center;gap:12px;height:150px;display:flex}.owner-row{grid-template-columns:110px 1fr 30px;align-items:center;gap:16px;display:grid}.owner-row div{background:#e5e7eb;border-radius:4px;height:12px}.owner-row i{background:#3b82f6;border-radius:4px;height:100%;display:block}.urgent-list{flex-direction:column;justify-content:center;height:150px;display:flex}.urgent-row{border-bottom:1px solid #eee;justify-content:space-between;align-items:center;height:30px;padding:0;display:flex}.urgent-row span{align-items:center;gap:10px;font-size:13px;font-weight:600;display:flex}.urgent-row em{color:#6b7280;font-style:normal;font-weight:500}.urgent-row b{color:#dc2626;font-size:13px;line-height:1}.urgent-row.clickable{cursor:pointer}.urgent-row.clickable:hover{background:#f8fafc}.project-board{box-sizing:border-box;background:#fff;border:1px solid #ddd;border-radius:8px;min-width:0;margin-top:12px;padding:16px;overflow:hidden}.project-board-head{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.project-board-head h3{margin:0}.project-bubbles{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.project-bubbles button{cursor:pointer;background:#fff;border:1px solid #ccc;border-radius:999px;height:30px;padding:0 14px}.project-bubbles button.active{color:#fff;background:#374151;font-weight:700}.bubble-scroll{overscroll-behavior-x:contain;scrollbar-width:none;width:100%;max-width:100%;overflow:auto hidden}.bubble-scroll::-webkit-scrollbar{display:none}.bubble-scroll .project-bubbles{flex-wrap:nowrap;gap:8px;width:max-content;display:flex}.bubble-scroll .project-bubbles button{flex-shrink:0}.project-task-table{border:1px solid #e5e7eb}.project-task-header,.project-task-row{grid-template-columns:80px 2fr 60px 150px 120px;align-items:center;min-height:34px;display:grid}.project-task-header{background:#f3f4f6;font-size:13px;font-weight:700}.project-task-row{border-top:1px solid #eee;font-size:13px}.project-task-header span,.project-task-row span{padding:0 10px}.project-progress-cell{align-items:center;gap:8px;display:flex}.project-progress-bar{background:#e5e7eb;border-radius:999px;width:90px;height:10px;overflow:hidden}.project-progress-bar i{background:#3b82f6;border-radius:999px;height:100%;display:block}.project-progress-cell b{min-width:34px;font-size:12px}.dashboard-detail-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:12px;margin-top:12px;display:grid}.owner-click{text-align:left;cursor:pointer;background:0 0;border:0;padding:0;font-size:13px;font-weight:600}.owner-click:hover{color:#2563eb;text-decoration:underline}.owner-task-header,.owner-task-row{grid-template-columns:90px 70px 2fr 60px 120px 110px;align-items:center;min-height:34px;display:grid}.owner-task-header{background:#f3f4f6;font-size:13px;font-weight:700}.owner-task-row{border-top:1px solid #eee;font-size:13px}.owner-task-header span,.owner-task-row span{padding:0 10px}.avg-progress{float:right;font-size:18px;font-weight:700}.project-progress-list{flex-direction:column;justify-content:center;gap:12px;height:150px;display:flex}.project-progress-row{grid-template-columns:100px 1fr 42px;align-items:center;gap:10px;font-size:13px;display:grid}.project-progress-row span{text-overflow:ellipsis;white-space:nowrap;font-weight:600;overflow:hidden}.project-progress-track{background:#e5e7eb;border-radius:999px;height:10px;overflow:hidden}.project-progress-track i{background:#3b82f6;border-radius:999px;height:100%;display:block}.project-progress-row b{text-align:right;font-size:12px}.cell-memo{color:#000;pointer-events:none;z-index:100;background:#f6ff00;border-radius:14px;align-items:center;max-width:120px;padding:4px 10px;font-size:10px;font-weight:400;line-height:1.4;display:inline-flex;position:absolute;top:-5px;left:calc(100% - 15px);box-shadow:0 3px 8px #00000038}.cell-memo-text{white-space:nowrap;text-overflow:ellipsis;max-width:100px;display:block;overflow:hidden}.grid-cell{position:relative;overflow:visible}.memo-modal{background:#fff;border-radius:18px;width:420px;padding:22px;box-shadow:0 20px 60px #0f172a47}.memo-modal-head{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.memo-modal-head h3{margin:0;font-size:20px}.memo-modal-head span{color:#6b7280;font-size:13px}.memo-modal textarea{resize:none;box-sizing:border-box;border:1px solid #d1d5db;border-radius:12px;outline:none;width:100%;height:120px;padding:12px;font-size:14px}.memo-modal textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.memo-modal-actions{justify-content:space-between;align-items:center;margin-top:16px;display:flex}.memo-modal-right{gap:8px;display:flex}.memo-modal button{cursor:pointer;border:0;border-radius:999px;height:36px;padding:0 16px;font-weight:700}.memo-modal button.primary{color:#fff;background:#2563eb}.memo-modal button.danger{color:#dc2626;background:#fee2e2}.memo-modal button:not(.primary):not(.danger){color:#374151;background:#f3f4f6}@media (width<=900px){body{min-height:100dvh;overflow:auto}.app{min-height:100dvh;padding:8px;overflow:auto}.planner{touch-action:pan-x pan-y;overscroll-behavior:none;-webkit-overflow-scrolling:touch;overflow:auto}.planner-mobile-hide{display:none!important}.planner-inner{align-items:flex-start;min-width:max-content;display:flex}.timeline-panel{overscroll-behavior:contain;min-width:max-content}.info-panel{z-index:50;background:#fff;border-right:2px solid #777;width:150px;min-width:150px;position:sticky;left:0}.info-sticky-header{z-index:70;position:sticky;top:0}.info-header{grid-template-columns:50px 100px;width:150px;min-width:150px;max-width:150px}.info-header div:nth-child(2),.info-header div:nth-child(n+4),.task-row-fields .doc-cell,.task-row-fields input[list=owner-suggestions],.task-row-fields .status-cell,.task-row-fields .delete-btn{display:none}.project-cell{width:50px;min-width:50px;max-width:50px}.info-panel{width:150px;min-width:150px;max-width:150px}.timeline-panel{min-width:max-content}.timeline-header{z-index:30;position:sticky;top:0}.cell-memo{z-index:6}.topbar{height:auto;margin-bottom:8px}.header-row{flex-direction:column;align-items:flex-start;gap:6px;height:auto;padding-top:10px;padding-bottom:8px}.header-row h1,.toolbar input[type=date],.toolbar-separator,.add-task-btn{display:none}.project-cell input,.task-row-fields input{pointer-events:none;-webkit-user-select:none;user-select:none;cursor:default;background:#fff}.task-row-fields input:focus{outline:none}.page-tabs{margin-left:0}.page-tabs button{width:84px;height:30px;font-size:12px}.toolbar{scrollbar-width:none;flex-wrap:nowrap;align-items:center;gap:6px;height:34px;padding:0;overflow:auto hidden}.topbar:before{content:"";background:#f5f6fa;height:80px;position:absolute;top:-80px;left:0;right:0}.toolbar::-webkit-scrollbar{display:none}.toolbar button,.toolbar input{white-space:nowrap;flex:none;height:28px;padding:0 8px;font-size:11px}.dashboard{height:auto;min-height:calc(100dvh - 96px);padding:0 0 120px;overflow:visible}.dashboard-cards{scrollbar-width:none;gap:8px;margin-bottom:12px;display:flex;overflow-x:auto}.dashboard-cards::-webkit-scrollbar{display:none}.dashboard-card{flex-shrink:0;min-width:110px;height:46px;padding:8px 10px}.dashboard-card.simple span{font-size:11px}.dashboard-card.simple strong{font-size:14px}.dashboard-grid{grid-template-columns:1fr;gap:10px}.dashboard-panel{min-height:190px;padding:14px}.dashboard-detail-grid{grid-template-columns:1fr;gap:10px}.project-board-head{justify-content:space-between;align-items:center;display:flex}.project-board-head h3{font-size:18px}.project-board-head strong{white-space:nowrap;font-size:13px}.project-task-table{width:100%;min-width:0}.project-task-list{width:100px;min-width:100px;max-width:100px}.task-row-fields{grid-template-columns:100px;width:100px;min-width:100px;max-width:100px}.task-row-fields input{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.task-row-fields input:first-child{display:none}.project-task-header,.project-task-row{grid-template-columns:50px 2fr 55px 120px}.project-task-header span:nth-child(5),.project-task-row span:nth-child(5){display:none}.owner-task-header,.owner-task-row{grid-template-columns:70px minmax(100px,1fr) 55px 80px}.owner-task-header span:nth-child(6),.owner-task-row span:nth-child(6),.owner-task-header span:nth-child(2),.owner-task-row span:nth-child(2){display:none}.owner-task-header span,.owner-task-row span{text-overflow:ellipsis;word-break:keep-all;padding:0 4px;font-size:11px;overflow:hidden}.owner-task-row{min-height:40px}.owner-task-header span:nth-child(3),.owner-task-row span:nth-child(3){white-space:normal}.owner-task-header span:nth-child(4),.owner-task-row span:nth-child(4){white-space:nowrap;text-align:center}.owner-task-header{min-height:36px}.project-task-header span,.project-task-row span,.owner-task-header span,.owner-task-row span{word-break:keep-all;padding:0 6px;font-size:12px}.project-progress-bar{width:70px}.project-progress-cell{gap:5px}.project-progress-cell b{min-width:30px;font-size:11px}.owner-click{pointer-events:none;cursor:default;color:inherit;background:0 0;border:0;text-decoration:none}.owner-click:hover{color:inherit;text-decoration:none}}
