:root{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#1f2933;background:#f7f8fa;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0}#root{min-height:100vh}.app-shell{min-height:100vh;color:#1f2933;background:#f7f8fa}.topbar{display:flex;align-items:center;justify-content:space-between;gap:20px;min-height:76px;padding:14px 20px;border-bottom:1px solid #dce1e7;background:#fff}.brand{display:flex;align-items:center;gap:12px;min-width:280px}.back-button{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid #ccd3dc;border-radius:7px;color:#253044;background:#fff;cursor:pointer}.brand-mark{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:8px;color:#fff;background:#2563eb}.brand h1{margin:0;color:#111827;font-size:18px;font-weight:700;line-height:1.2}.brand p{margin:3px 0 0;color:#6b7280;font-size:12px;line-height:1.3}.project-name-input{width:min(340px,40vw);height:32px;padding:0;color:#111827;font-size:18px;font-weight:700}.toolbar{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap}.user-email,.sync-error{display:inline-flex;align-items:center;min-height:32px;max-width:220px;overflow:hidden;color:#64748b;font-size:12px;text-overflow:ellipsis;white-space:nowrap}.sync-error{color:#b42318}button{border:0;font:inherit}.segmented{display:inline-flex;height:36px;padding:3px;border:1px solid #ccd3dc;border-radius:7px;background:#eef2f6}.segmented button{min-width:42px;border-radius:5px;color:#4b5563;background:transparent;cursor:pointer}.segmented button.active{color:#111827;background:#fff;box-shadow:0 1px 2px #0f172a1f}.primary-button,.secondary-button,.icon-button{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:36px;padding:0 12px;border-radius:7px;cursor:pointer;white-space:nowrap}.primary-button{color:#fff;background:#2563eb}.primary-button:disabled{cursor:default;opacity:.65}.secondary-button,.icon-button{color:#253044;border:1px solid #ccd3dc;background:#fff}.filter-control{display:inline-flex;align-items:center;gap:7px;height:36px;padding:0 10px;border:1px solid #ccd3dc;border-radius:7px;color:#475569;background:#fff}.filter-control select{width:144px;height:28px;padding:0;border:0;color:#253044;background:transparent}.workspace{display:grid;grid-template-columns:minmax(420px,34vw) minmax(0,1fr);height:calc(100vh - 77px);min-height:520px}.project-dashboard{padding:24px}.auth-screen{display:grid;min-height:100vh;place-items:center;padding:24px}.auth-panel{display:flex;flex-direction:column;gap:12px;width:min(360px,100%);padding:22px;border:1px solid #dce1e7;border-radius:8px;background:#fff;box-shadow:0 10px 25px #0f172a14}.auth-panel h1{margin:4px 0 2px;color:#111827;font-size:20px;line-height:1.3}.auth-panel input{height:38px;padding:0 10px;border-color:#ccd3dc;background:#fff}.auth-message{margin:0;color:#b42318;font-size:13px;line-height:1.5}.text-button{min-height:32px;color:#2563eb;background:transparent;cursor:pointer}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;max-width:1120px}.project-card{display:flex;align-items:flex-start;flex-direction:column;gap:8px;min-height:116px;padding:16px;border:1px solid #dce1e7;border-radius:8px;color:#253044;background:#fff;text-align:left;cursor:pointer}.project-card:hover{border-color:#9db7e8;box-shadow:0 8px 18px #0f172a14}.project-card-title{color:#111827;font-size:16px;font-weight:700;line-height:1.35}.project-card-meta,.project-card-date{color:#64748b;font-size:13px;line-height:1.35}.ticket-pane{overflow:auto;border-right:1px solid #dce1e7;background:#fff}.pane-head{display:flex;align-items:center;justify-content:space-between;height:39px;padding:0 12px;color:#5f6b7a;border-bottom:1px solid #e5e9ef;background:#f9fafb;font-size:12px;font-weight:700}.ticket-list{min-width:420px}.lane-row{display:flex;align-items:center;gap:8px;height:44px;padding:0 12px;color:#c65f00;border-bottom:1px solid #edf0f4;background:#fffaf2;font-size:13px;font-weight:700}.ticket-row{display:grid;grid-template-columns:22px minmax(120px,1fr) 118px 28px 28px;align-items:center;gap:6px;min-height:44px;padding-top:6px;padding-right:8px;padding-bottom:6px;border-bottom:1px solid #edf0f4}.tree-toggle,.row-action{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:5px;color:#64748b;background:transparent;cursor:pointer}.tree-toggle:disabled{cursor:default;opacity:.35}.row-action:hover,.tree-toggle:not(:disabled):hover{color:#111827;background:#eef2f6}.row-action.danger:hover{color:#b42318;background:#fff1f1}input,select,textarea{min-width:0;height:30px;box-sizing:border-box;border:1px solid transparent;border-radius:6px;color:#1f2937;background:transparent;font:inherit}input:hover,input:focus,select:hover,select:focus,textarea:hover,textarea:focus{border-color:#cbd5e1;background:#fff;outline:none}.title-input{align-self:stretch;width:100%;height:100%;padding:0 8px;font-weight:650;line-height:1.35;overflow:hidden;resize:none;white-space:pre-wrap;word-break:break-word}.assignee-select{padding:0 7px;color:#475569;font-size:13px}.milestone-editor{border-top:1px solid #dce1e7}.milestone-row{display:grid;grid-template-columns:20px minmax(110px,1fr) 132px 28px;align-items:center;gap:6px;height:44px;padding:0 8px 0 12px;border-bottom:1px solid #edf0f4;color:#dc6d00}.milestone-row input{padding:0 7px}.milestone-row input[type=date]{color:#475569;font-size:13px}.chart-pane{min-width:0;overflow:hidden;background:#f7f8fa}.timeline-scroll{height:100%;overflow:auto}.timeline-canvas{position:relative;min-height:100%}.timeline-header{position:sticky;top:0;z-index:4;display:flex;height:39px;border-bottom:1px solid #dce1e7;background:#fff}.timeline-header.day-mode{display:block;height:58px}.month-header-row,.day-header-row{display:flex}.month-header-row{height:22px;border-bottom:1px solid #e5e9ef}.day-header-row{height:36px}.month-cell{flex:0 0 auto;box-sizing:border-box;display:flex;align-items:center;padding-left:8px;border-right:1px solid #d4dbe5;color:#344054;background:#f8fafc;font-size:12px;font-weight:700;white-space:nowrap}.day-cell,.week-cell{flex:0 0 auto;box-sizing:border-box;border-right:1px solid #e5e9ef;color:#667085;text-align:center;font-size:11px}.day-cell{display:flex;flex-direction:column;justify-content:center;gap:1px}.day-cell strong{color:#243041;font-size:13px;line-height:1}.today-cell{background:#fff7ed}.day-cell.saturday{color:#2563eb;background:#eff6ff}.day-cell.sunday,.day-cell.holiday{color:#c2410c;background:#fff1f2}.day-cell.today-cell{box-shadow:inset 0 -3px #ef4444}.week-cell{display:flex;align-items:center;justify-content:flex-start;padding-left:10px;color:#344054;font-weight:700}.chart-body{position:relative;min-height:calc(100% - 58px);background-image:linear-gradient(to right,#e7ebf0 1px,transparent 1px);background-size:var(--grid-size, 36px) 100%}.chart-body.week-mode{min-height:calc(100% - 39px)}.day-shade{position:absolute;top:0;bottom:0;z-index:0;pointer-events:none}.day-shade.saturday{background:#2563eb0e}.day-shade.sunday,.day-shade.holiday{background:#f43f5e12}.milestone-lane,.chart-row{position:relative;box-sizing:border-box;border-bottom:1px solid #edf0f4;z-index:1}.milestone-lane{background:#fffaf2cc}.chart-row{min-height:44px;background:transparent}.chart-row:nth-child(odd){background:#f8fafc6b}.task-bar{position:absolute;top:8px;display:grid;grid-template-columns:14px minmax(0,1fr) 14px;align-items:center;height:28px;min-width:24px;box-sizing:border-box;border:1px solid #1d4ed8;border-radius:6px;color:#fff;background:#2563eb;box-shadow:0 1px 2px #2563eb38;cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none;z-index:2}.task-bar:active{cursor:grabbing}.bar-label{overflow:hidden;padding:0 4px;text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:700;line-height:1}.business-days-badge{position:absolute;display:inline-flex;align-items:center;height:28px;padding:0 7px;border:1px solid #cbd5e1;border-radius:6px;color:#475569;background:#ffffffeb;font-size:12px;font-weight:700;white-space:nowrap;z-index:2}.resize-handle{display:inline-flex;align-items:center;justify-content:center;height:100%;color:#ffffffd1;cursor:ew-resize}.milestone-marker{position:absolute;top:12px;display:inline-flex;align-items:center;gap:5px;max-width:180px;color:#c65f00;font-size:12px;font-weight:700;line-height:1;transform:translateY(-1px);white-space:nowrap}.milestone-marker span{overflow:hidden;text-overflow:ellipsis}.today-line{position:absolute;top:0;bottom:0;width:2px;z-index:3;background:#ef4444;pointer-events:none}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;display:flex;align-items:flex-start;justify-content:center;padding-top:86px;background:#0f172a3d}.assignee-modal{width:min(420px,calc(100vw - 32px));max-height:calc(100vh - 132px);overflow:hidden;border:1px solid #dce1e7;border-radius:8px;background:#fff;box-shadow:0 20px 45px #0f172a33}.modal-head{display:flex;align-items:center;justify-content:space-between;height:48px;padding:0 12px 0 16px;border-bottom:1px solid #e5e9ef}.modal-head h2{margin:0;color:#111827;font-size:15px;line-height:1.2}.modal-body{max-height:calc(100vh - 180px);overflow:auto;padding:8px}.assignee-modal-row{display:grid;grid-template-columns:minmax(0,1fr) 28px;align-items:center;gap:8px;min-height:42px}.assignee-modal-row+.assignee-modal-row{border-top:1px solid #edf0f4}.assignee-modal-row input{padding:0 8px}.assignee-modal-row.add{margin-top:8px;padding-top:8px}@media(max-width:900px){.topbar{align-items:flex-start;flex-direction:column}.workspace{grid-template-columns:1fr;height:auto}.ticket-pane{max-height:45vh;border-right:0;border-bottom:1px solid #dce1e7}.chart-pane{height:55vh}}
