.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:var(--color-background-primary);border-radius:var(--border-radius-lg);padding:32px 36px;max-width:560px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 8px 40px #0000002e}.modal-actions{display:flex;justify-content:flex-end;gap:8px;padding-top:16px;border-top:.5px solid var(--color-border-tertiary);margin-top:8px}.right-col{display:flex;flex-direction:column;gap:1rem;position:sticky;top:1rem}.overview-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}@media(max-width:600px){.overview-grid{grid-template-columns:repeat(2,1fr)}}.overview-metric{background:var(--color-background-primary);border:.5px solid var(--color-border-tertiary);border-radius:var(--border-radius-lg);padding:12px 14px;text-align:center}.metric-val{font-size:22px;font-weight:600}.metric-label{font-size:11px;color:var(--color-text-secondary);margin-top:2px}.section-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary);margin-bottom:8px}.urgent-bar-row{display:flex;align-items:flex-start;gap:8px;padding:7px 0;border-bottom:.5px solid var(--color-border-tertiary);cursor:pointer}.urgent-bar-row:last-child{border-bottom:none}.urgent-bar-row:hover{background:var(--color-background-secondary);margin:0 -6px;padding-left:6px;padding-right:6px;border-radius:6px}.urgent-bar-name{font-size:13px;font-weight:500;margin-bottom:2px}.urgent-bar-sub{font-size:11px;color:var(--color-text-secondary);margin-bottom:3px}.urgent-bar-track{height:4px;background:var(--color-background-secondary);border-radius:2px;overflow:hidden;margin-top:3px}.urgent-bar-fill{height:100%;border-radius:0;transition:width .3s}.urgent-bar-days{font-size:11px;white-space:nowrap;padding-top:2px}.focus-card{border:.5px solid var(--color-border-tertiary);border-radius:var(--border-radius-md);padding:10px 12px;margin-bottom:8px;cursor:pointer;background:var(--color-background-primary)}.focus-card:hover{background:var(--color-background-secondary)}.focus-card-header{display:flex;align-items:center;gap:7px;margin-bottom:0}.focus-card-name{flex:1;font-size:13px;font-weight:500}.focus-card-cat{font-size:11px;color:var(--color-text-secondary)}.focus-card-score{font-size:12px;font-weight:600;min-width:24px;text-align:right}.focus-card-substep-row{display:flex;align-items:center;gap:6px;margin-top:5px;margin-left:23px;margin-bottom:2px}.focus-card-substep{font-size:11px;color:var(--color-text-secondary);margin-top:3px;margin-bottom:3px;margin-left:23px}.focus-card-bar-row{display:flex;align-items:center;gap:8px;margin-top:6px}.focus-bar-track{flex:1;height:4px;background:#e0e0e0;border-radius:2px;overflow:hidden;box-shadow:none;outline:none;border:none}.focus-bar-fill{height:100%;border-radius:0;box-shadow:none;transition:width .3s}.focus-card-meta{display:flex;align-items:center;gap:6px;flex-shrink:0}.focus-hrs-badge{font-size:11px;background:var(--color-background-info);color:var(--color-text-info);border-radius:10px;padding:1px 7px}.today-plan-panel{border:.5px solid var(--color-border-tertiary);border-radius:var(--border-radius-lg);background:var(--color-background-primary);padding:14px 16px}.today-plan-title{font-size:13px;font-weight:500;margin-bottom:10px;display:flex;justify-content:space-between;align-items:center}.today-plan-item{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:.5px solid var(--color-border-tertiary);cursor:pointer}.today-plan-item:last-child{border-bottom:none}.today-plan-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.today-plan-name{font-size:13px}.today-plan-name.done{text-decoration:line-through;color:var(--color-text-secondary)}.today-plan-meta{font-size:11px;color:var(--color-text-tertiary)}.cat-list{display:flex;flex-direction:column;gap:12px}.cat-card{background:var(--color-bg-primary);border:.5px solid var(--color-border-tertiary);border-radius:var(--radius-lg);overflow:hidden}.cat-header{display:flex;align-items:center;gap:10px;padding:12px 16px;cursor:pointer;-webkit-user-select:none;user-select:none}.cat-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.cat-title{font-size:15px;font-weight:500;flex:1}.cat-meta{font-size:12px;color:var(--color-text-secondary)}.cat-chevron{font-size:11px;color:var(--color-text-tertiary);transition:transform .2s}.cat-chevron.open{transform:rotate(90deg)}.cat-body{border-top:.5px solid var(--color-border-tertiary);padding:12px 16px}.task-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.task-item{border:.5px solid var(--color-border-tertiary);border-radius:var(--radius-md);overflow:hidden}.task-row{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer}.task-check.done{background:var(--color-bg-success);border-color:var(--color-border-success);color:var(--color-text-success)}.task-check.in-progress{background:var(--color-bg-info);border-color:var(--color-border-info);color:var(--color-text-info)}.task-name{flex:1;font-size:13px;font-weight:500}.task-name.done{text-decoration:line-through;color:var(--color-text-secondary)}.task-due{font-size:11px;color:var(--color-text-secondary);white-space:nowrap}.badge{font-size:11px;padding:2px 8px;border-radius:12px;font-weight:500;white-space:nowrap}.badge-low{background:var(--color-bg-success);color:var(--color-text-success)}.badge-med{background:var(--color-bg-warning);color:var(--color-text-warning)}.badge-critical{background:var(--color-bg-danger);color:var(--color-text-danger)}.task-detail{padding:0 12px 12px;border-top:.5px solid var(--color-border-tertiary)}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:10px 0;font-size:12px}.detail-field{display:flex;flex-direction:column;gap:2px}.detail-label{color:var(--color-text-secondary)}.detail-val{font-weight:500}.progress-wrap{margin:10px 0}.progress-label{font-size:12px;color:var(--color-text-secondary);display:flex;justify-content:space-between;margin-bottom:4px}.progress-track{background:var(--color-bg-secondary);border-radius:4px;height:6px}.progress-fill{height:100%;border-radius:4px;background:var(--color-bg-info);border:2px solid var(--color-border-info);transition:width .3s}.substep-list{display:flex;flex-direction:column;gap:4px;margin:8px 0}.substep{display:flex;align-items:center;gap:8px;font-size:12px}.substep-check{width:14px;height:14px;border-radius:3px;border:1.5px solid var(--color-border-secondary);flex-shrink:0;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:9px}.substep-check.done{background:var(--color-bg-success);border-color:var(--color-border-success);color:var(--color-text-success)}.substep-text{flex:1}.substep-text.done{text-decoration:line-through;color:var(--color-text-secondary)}.task-actions{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap}.empty-state{display:flex;flex-direction:column;align-items:center;gap:10px;padding:3rem 1rem;text-align:center}.empty-icon{font-size:36px}.empty-title{font-size:15px;font-weight:500}.empty-sub{font-size:13px;color:var(--color-text-secondary);max-width:300px}.planner{padding-bottom:2rem}.planner-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:8px;flex-wrap:wrap}.planner-nav,.planner-actions{display:flex;gap:6px;flex-wrap:wrap}.planner-layout{display:grid;grid-template-columns:200px 1fr;gap:1rem;align-items:start;min-width:0}.planner-sidebar-wrap{display:flex;flex-direction:column;gap:0}.sidebar-toggle{display:none;align-items:center;gap:4px;background:var(--color-bg-secondary);border:.5px solid var(--color-border-tertiary);border-radius:var(--radius-md);padding:8px 12px;font-size:13px;font-weight:500;cursor:pointer;color:var(--color-text-primary);width:100%;text-align:left;margin-bottom:4px}.planner-sidebar{border:.5px solid var(--color-border-tertiary);border-radius:var(--radius-lg);background:var(--color-bg-primary);padding:12px 14px;position:sticky;top:1rem;max-height:80vh;overflow-y:auto}.sidebar-title{font-size:13px;font-weight:500;margin-bottom:10px;display:flex;justify-content:space-between;align-items:center}.sidebar-count{font-size:11px;background:var(--color-bg-secondary);border-radius:10px;padding:1px 7px;color:var(--color-text-secondary)}.sidebar-empty{font-size:12px;color:var(--color-text-tertiary);padding:4px 0}.sidebar-card{border-left:3px solid #888;background:var(--color-bg-secondary);border-radius:var(--radius-md);padding:7px 10px;margin-bottom:7px;cursor:grab;font-size:12px;position:relative;touch-action:pan-y}.sidebar-card:active{cursor:grabbing}.sidebar-card-name{font-weight:500;margin-bottom:2px}.sidebar-card-meta{color:var(--color-text-secondary);font-size:11px}.sidebar-days{display:flex;flex-wrap:wrap;gap:3px;margin-top:5px}.sidebar-day-chip{display:inline-flex;align-items:center;gap:3px;font-size:10px;padding:1px 5px;background:var(--color-bg-primary);border:.5px solid var(--color-border-secondary);border-radius:3px}.sidebar-day-chip button{background:none;border:none;cursor:pointer;font-size:12px;color:var(--color-text-tertiary);padding:2px;line-height:1;min-width:20px;min-height:20px}.sidebar-schedule-btn{position:absolute;top:6px;right:6px;background:none;border:none;cursor:pointer;font-size:14px;opacity:.5;padding:4px;line-height:1;border-radius:var(--radius-sm);min-width:28px;min-height:28px;display:flex;align-items:center;justify-content:center}.sidebar-schedule-btn:hover,.sidebar-schedule-btn:focus{opacity:1;background:var(--color-bg-tertiary)}.planner-weeks{display:flex;flex-direction:column;gap:20px;overflow-x:auto;-webkit-overflow-scrolling:touch;min-width:0}.planner-week-grid{display:grid;grid-template-columns:repeat(7,auto);gap:4px;min-width:420px}.planner-day-header{text-align:center;font-size:11px;font-weight:600;color:var(--color-text-secondary);padding:3px 6px 4px;border-bottom:1.5px solid transparent;white-space:nowrap}.planner-day-header.today{color:var(--color-text-info);border-bottom-color:var(--color-text-info)}.planner-day-header.past{opacity:.45}.planner-day-date{font-weight:400;font-size:10px}.planner-col{min-height:80px;border-radius:var(--radius-md);padding:4px;background:var(--color-bg-secondary);border:1px solid var(--color-border-tertiary);transition:background .15s;width:100%;box-sizing:border-box}.planner-col.drag-over{background:var(--color-bg-info);border-color:var(--color-border-info)}.planner-col.over{border-color:var(--color-border-danger)}.planner-col.past{opacity:.5}.day-load-badge{font-size:9px;color:var(--color-text-secondary);text-align:right;margin-bottom:2px}.day-load-badge.over{color:var(--color-text-danger);font-weight:600}.due-chip{font-size:9px;padding:2px 5px;border-radius:8px;margin-bottom:2px;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:default}.planner-task-card{border-radius:var(--radius-sm);padding:5px 7px;margin-bottom:4px;color:#fff;cursor:grab;display:flex;align-items:flex-start;gap:4px;position:relative;font-size:11px;touch-action:pan-y}.planner-task-card:active{cursor:grabbing}body.is-touch-dragging .planner-task-card,body.is-touch-dragging .sidebar-card{touch-action:none}.card-body{flex:1;min-width:0}.card-name{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.card-meta{display:flex;align-items:center;gap:4px;flex-wrap:wrap;margin-top:2px}.card-due{opacity:.85;font-size:10px}.card-remove{background:none;border:none;cursor:pointer;color:#ffffffb3;font-size:14px;padding:4px;line-height:1;flex-shrink:0;min-width:28px;min-height:28px;display:flex;align-items:center;justify-content:center}.card-remove:hover{color:#fff}.hrs-badge{background:#ffffff40;border:none;border-radius:3px;color:inherit;cursor:pointer;font-size:10px;padding:3px 7px;font-family:var(--font-sans);min-height:24px;display:inline-flex;align-items:center}.hrs-badge:hover{background:#fff6}.hrs-badge.hrs-custom{background:#ffffff73;font-weight:700}.hrs-popover{position:absolute;top:calc(100% + 4px);left:0;z-index:50;background:#2a2a2a;border-radius:var(--radius-md);padding:8px 10px;min-width:150px;box-shadow:0 4px 16px #0000004d}.hrs-popover-label{font-size:10px;color:#ffffffb3;margin-bottom:6px}.hrs-popover-row{display:flex;gap:5px;align-items:center}.hrs-popover-row input{width:54px;font-size:13px;padding:3px 6px;border-radius:4px;border:1px solid rgba(255,255,255,.3);background:#ffffff1f;color:#fff;text-align:center;font-family:var(--font-sans)}.hrs-popover-row button{font-size:11px;padding:5px 10px;border-radius:4px;border:none;background:#ffffff40;color:#fff;cursor:pointer;font-family:var(--font-sans);min-height:28px}.hrs-popover-row button:hover{background:#fff6}.touch-ghost{position:fixed;pointer-events:none;z-index:9999;border-radius:var(--radius-sm);padding:5px 10px;color:#fff;font-size:12px;font-weight:500;opacity:.9;white-space:nowrap;box-shadow:0 4px 12px #00000059;transform:rotate(-2deg);will-change:transform}.day-picker-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:200;display:flex;align-items:flex-end;justify-content:center}@media(min-width:500px){.day-picker-overlay{align-items:center}}.day-picker-modal{background:var(--color-bg-primary);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:16px;width:100%;max-width:560px;max-height:80vh;overflow-y:auto;box-shadow:0 -4px 24px #00000040}@media(min-width:500px){.day-picker-modal{border-radius:var(--radius-lg);max-height:70vh}}.day-picker-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-size:14px}.day-picker-close{background:none;border:none;cursor:pointer;font-size:20px;color:var(--color-text-secondary);padding:4px 8px;line-height:1;min-width:36px;min-height:36px}.day-picker-week{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:6px}.day-picker-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:6px 2px;border-radius:var(--radius-md);border:1px solid var(--color-border-tertiary);background:var(--color-bg-secondary);cursor:pointer;font-size:10px;color:var(--color-text-primary);gap:2px;min-height:44px}.day-picker-btn.picked{background:var(--color-bg-info);border-color:var(--color-border-info);font-weight:600}.dpb-name{font-weight:600;font-size:11px}.dpb-date{font-size:9px;color:var(--color-text-secondary)}.day-picker-btn.picked .dpb-date{color:var(--color-text-info)}.day-picker-hint{font-size:11px;color:var(--color-text-tertiary);margin-top:8px;text-align:center}.agenda-view{display:flex;flex-direction:column;gap:0}.agenda-nav{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:12px;flex-wrap:wrap}.agenda-nav-btns,.agenda-actions{display:flex;gap:4px}.agenda-week-label{font-size:12px;color:var(--color-text-secondary);flex:1;text-align:center;white-space:nowrap}.agenda-unscheduled{border:.5px solid var(--color-border-tertiary);border-radius:var(--radius-lg);background:var(--color-bg-primary);margin-bottom:12px;overflow:hidden}.agenda-section-toggle{display:flex;align-items:center;gap:6px;width:100%;padding:10px 14px;background:none;border:none;cursor:pointer;font-size:13px;font-weight:500;color:var(--color-text-primary);text-align:left}.agenda-unsch-row{display:flex;align-items:center;gap:10px;padding:9px 14px;border-top:.5px solid var(--color-border-tertiary);border-left:3px solid #888;cursor:pointer;position:relative}.agenda-unsch-row:active{background:var(--color-bg-secondary)}.agenda-unsch-name{font-size:13px;font-weight:500;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.agenda-unsch-meta{font-size:11px;color:var(--color-text-secondary);white-space:nowrap}.agenda-schedule-btn{background:none;border:none;cursor:pointer;font-size:16px;padding:6px;min-width:36px;min-height:36px;display:flex;align-items:center;justify-content:center;opacity:.6;flex-shrink:0}.agenda-schedule-btn:active{opacity:1}.agenda-day{margin-bottom:4px;border-radius:var(--radius-lg);overflow:hidden;border:.5px solid var(--color-border-tertiary);background:var(--color-bg-primary)}.agenda-day.agenda-past{opacity:.6}.agenda-day-header{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;background:var(--color-bg-secondary);border-bottom:.5px solid var(--color-border-tertiary)}.agenda-today .agenda-day-header{background:var(--color-bg-info);border-bottom-color:var(--color-border-info)}.agenda-day-label{font-size:13px;font-weight:600;color:var(--color-text-primary)}.agenda-today .agenda-day-label{color:var(--color-text-info)}.agenda-load-badge{font-size:11px;color:var(--color-text-secondary);background:var(--color-bg-primary);border-radius:10px;padding:1px 8px}.agenda-load-badge.over{color:var(--color-text-danger);font-weight:600}.agenda-due-row{display:flex;align-items:center;gap:8px;padding:8px 14px;border-left:3px solid #888;border-top:.5px solid var(--color-border-tertiary);cursor:pointer;font-size:13px}.agenda-due-row:active{background:var(--color-bg-secondary)}.agenda-due-icon{flex-shrink:0;font-size:14px}.agenda-due-name{flex:1;color:var(--color-text-secondary);font-style:italic}.agenda-task-row{display:flex;align-items:center;gap:8px;padding:10px 14px;border-left:3px solid #888;border-top:.5px solid var(--color-border-tertiary);cursor:pointer;position:relative}.agenda-task-row:active{background:var(--color-bg-secondary)}.agenda-task-name{flex:1;font-size:14px;font-weight:500;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--color-text-primary)}.agenda-task-meta{display:flex;align-items:center;gap:5px;flex-shrink:0}.agenda-task-hrs{font-size:11px;color:#fff;border-radius:3px;padding:2px 6px;white-space:nowrap}.agenda-task-due{font-size:11px;color:var(--color-text-secondary);white-space:nowrap}.agenda-remove-btn{background:none;border:none;cursor:pointer;font-size:16px;color:var(--color-text-tertiary);padding:6px;min-width:36px;min-height:36px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.agenda-remove-btn:active{color:var(--color-text-danger)}.agenda-schedule-btn-sm{background:none;border:none;cursor:pointer;font-size:14px;padding:6px;min-width:36px;min-height:36px;display:flex;align-items:center;justify-content:center;opacity:.55;flex-shrink:0}.agenda-schedule-btn-sm:active{opacity:1}.agenda-empty{padding:32px 16px;text-align:center;color:var(--color-text-tertiary);font-size:13px}.gcal-pane{max-width:760px;padding-bottom:3rem}.gcal-hero{text-align:center;padding:3rem 1rem 2rem}.gcal-hero-icon{font-size:3rem;margin-bottom:1rem}.gcal-hero h2{font-size:20px;font-weight:600;margin-bottom:.5rem}.gcal-hero p{font-size:14px;color:var(--color-text-secondary);max-width:440px;margin:0 auto 1.5rem;line-height:1.5}.gcal-connect-btn{font-size:14px;padding:10px 20px}.gcal-setup{border:.5px solid var(--color-border-tertiary);border-radius:var(--radius-lg);background:var(--color-bg-secondary);padding:18px 20px;margin-top:2rem}.gcal-setup h3{font-size:13px;font-weight:600;margin-bottom:10px}.gcal-setup ol{padding-left:1.25rem;font-size:13px;line-height:1.8;color:var(--color-text-secondary)}.gcal-setup ol li{margin-bottom:2px}.gcal-setup a{color:var(--color-text-info)}.gcal-setup code{background:var(--color-bg-primary);border:.5px solid var(--color-border-secondary);border-radius:3px;padding:1px 5px;font-size:12px;font-family:monospace}.gcal-warning{margin-top:12px;font-size:12px;color:var(--color-text-warning);background:var(--color-bg-warning);border-radius:var(--radius-md);padding:8px 12px}.gcal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.gcal-connected-badge{font-size:13px;color:var(--color-text-success);font-weight:500}.gcal-error{font-size:13px;color:var(--color-text-danger);background:var(--color-bg-danger);border-radius:var(--radius-md);padding:8px 12px;margin-bottom:8px}.gcal-panel-tabs{display:flex;gap:4px;margin-bottom:20px;border-bottom:1px solid var(--color-border-tertiary);padding-bottom:0}.gcal-panel-tab{background:none;border:none;cursor:pointer;font-size:13px;font-weight:500;padding:8px 14px;color:var(--color-text-secondary);border-bottom:2px solid transparent;margin-bottom:-1px;border-radius:0}.gcal-panel-tab:hover{color:var(--color-text-primary)}.gcal-panel-tab.active{color:var(--color-text-info);border-bottom-color:var(--color-text-info)}.gcal-section-label{font-size:12px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}.gcal-cal-selector{margin-bottom:16px}.gcal-cal-list{display:flex;flex-wrap:wrap;gap:6px}.gcal-cal-item{display:flex;align-items:center;gap:6px;font-size:13px;cursor:pointer;padding:5px 10px;border-radius:var(--radius-full);border:.5px solid var(--color-border-secondary);background:var(--color-bg-secondary)}.gcal-cal-item:hover{background:var(--color-bg-tertiary)}.gcal-cal-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.gcal-working-hours{margin-bottom:16px}.gcal-hours-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.gcal-hours-row label{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--color-text-secondary)}.gcal-hours-row select{font-size:13px;padding:4px 8px;border-radius:var(--radius-md);border:.5px solid var(--color-border-secondary);background:var(--color-bg-secondary);color:var(--color-text-primary)}.gcal-empty{text-align:center;padding:3rem 1rem;color:var(--color-text-secondary);font-size:13px}.gcal-empty p{margin-top:10px;font-size:12px;color:var(--color-text-tertiary)}.gcal-fb-grid{display:flex;flex-direction:column;gap:6px}.gcal-fb-row{display:grid;grid-template-columns:120px 1fr 160px;align-items:center;gap:10px;padding:6px 10px;border-radius:var(--radius-md);background:var(--color-bg-secondary);font-size:12px}@media(max-width:600px){.gcal-fb-row{grid-template-columns:90px 1fr 120px;gap:6px}}.gcal-fb-row.gcal-today{background:var(--color-bg-info)}.gcal-fb-row.gcal-past{opacity:.5}.gcal-fb-row.gcal-over{background:var(--color-bg-danger)}.gcal-fb-date{font-size:12px;font-weight:500;white-space:nowrap;color:var(--color-text-primary)}.gcal-today .gcal-fb-date{color:var(--color-text-info)}.gcal-fb-bar-wrap{position:relative;height:8px;background:var(--color-bg-primary);border-radius:4px;overflow:visible}.gcal-fb-bar{position:absolute;left:0;top:0;height:100%;border-radius:4px;background:var(--color-success, #437a22);opacity:.5;transition:width .3s ease}.gcal-fb-plan-bar{position:absolute;left:0;top:0;height:100%;border-radius:4px;background:var(--color-text-info);opacity:.7;transition:width .3s ease}.gcal-fb-plan-bar.over{background:var(--color-text-danger)}.gcal-fb-label{display:flex;flex-direction:column;gap:1px;text-align:right}.gcal-fb-free{color:var(--color-text-secondary)}.gcal-fb-planned{color:var(--color-text-info);font-weight:500}.gcal-fb-planned.over{color:var(--color-text-danger)}.gcal-blocks-intro{font-size:13px;color:var(--color-text-secondary);margin-bottom:16px;line-height:1.5}.gcal-task-block{border:.5px solid var(--color-border-tertiary);border-radius:var(--radius-lg);background:var(--color-bg-secondary);padding:12px 14px;margin-bottom:10px}.gcal-task-name{font-size:14px;font-weight:600;margin-bottom:2px}.gcal-task-due{font-size:11px;color:var(--color-text-secondary);margin-bottom:8px}.gcal-task-days{display:flex;flex-direction:column;gap:5px}.gcal-day-row{display:flex;align-items:center;gap:8px;font-size:12px}.gcal-day-label{min-width:100px;color:var(--color-text-secondary)}.gcal-day-hrs{min-width:36px;font-weight:500}.gcal-push-btn{font-size:11px;padding:4px 10px;border-radius:var(--radius-md);border:.5px solid var(--color-border-secondary);background:var(--color-bg-primary);color:var(--color-text-primary);cursor:pointer;min-height:28px}.gcal-push-btn:hover:not(:disabled){background:var(--color-bg-info);border-color:var(--color-border-info)}.gcal-push-btn:disabled{opacity:.5;cursor:default}.gcal-push-btn.done{background:var(--color-bg-success);color:var(--color-text-success);border-color:transparent}.gcal-push-btn.error{background:var(--color-bg-danger);color:var(--color-text-danger);border-color:transparent}:root{--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--color-text-primary: #1a1a1a;--color-text-secondary: #666;--color-text-tertiary: #999;--color-text-danger: #c0392b;--color-text-success: #1a7a4a;--color-text-warning: #92610a;--color-text-info: #1a5ca8;--color-background-primary: #ffffff;--color-background-secondary: #f5f5f5;--color-background-danger: #fdecea;--color-background-success: #e6f4ed;--color-background-warning: #fef3dc;--color-background-info: #e8f0fc;--color-border-primary: #d0d0d0;--color-border-secondary: #d8d8d8;--color-border-tertiary: #ebebeb;--color-border-danger: #e8a09a;--color-border-success: #7ec8a0;--color-border-info: #90b4e8;--border-radius-sm: 4px;--border-radius-md: 6px;--border-radius-lg: 10px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}#root{max-width:1080px;margin:0 auto;padding:0 1.5rem}.toolbar{display:flex;justify-content:flex-end;align-items:center;gap:8px;padding:10px 0 0;border-bottom:.5px solid var(--color-border-tertiary);margin-bottom:0}.toolbar-label{font-size:11px;color:var(--color-text-tertiary);margin-right:auto}.import-export-bar{display:flex;align-items:center;gap:6px}.import-export-flash{font-size:11px;color:var(--color-text-success);padding:2px 8px;background:var(--color-background-success);border-radius:var(--border-radius-sm);white-space:nowrap}.import-export-flash.error{color:var(--color-text-danger);background:var(--color-background-danger)}.app{padding:1.5rem 0}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.header h1{font-size:20px;font-weight:500}.btn{background:transparent;border:.5px solid var(--color-border-secondary);border-radius:var(--border-radius-md);padding:6px 14px;font-size:13px;cursor:pointer;color:var(--color-text-primary);font-family:var(--font-sans)}.btn:hover{background:var(--color-background-secondary)}.btn-primary{background:var(--color-text-primary);color:var(--color-background-primary);border-color:var(--color-text-primary)}.btn-primary:hover{opacity:.85}.btn-sm{padding:3px 10px;font-size:12px}.btn-danger{border-color:var(--color-border-danger);color:var(--color-text-danger)}.btn-danger:hover{background:var(--color-background-danger)}.btn:disabled{opacity:.45;cursor:default}.tabs{display:flex;gap:4px;border-bottom:.5px solid var(--color-border-tertiary);margin-bottom:1.5rem}.tab{padding:8px 16px;font-size:13px;cursor:pointer;color:var(--color-text-secondary);border-bottom:2px solid transparent;margin-bottom:-1px}.tab.active{color:var(--color-text-primary);border-bottom-color:var(--color-text-primary);font-weight:500}.plan-layout{display:grid;grid-template-columns:1fr 260px;gap:1.5rem;align-items:start}@media(max-width:680px){.plan-layout{grid-template-columns:1fr}.quick-panel{order:-1}}.quick-panel{border:.5px solid var(--color-border-tertiary);border-radius:var(--border-radius-lg);background:var(--color-background-primary);padding:14px 16px;position:sticky;top:1rem}.quick-panel-title{font-size:13px;font-weight:500;margin-bottom:10px;display:flex;justify-content:space-between;align-items:center}.quick-add-row{display:flex;gap:6px;margin-bottom:10px}.quick-add-input{flex:1;font-family:var(--font-sans);font-size:12px;padding:5px 8px;border:.5px solid var(--color-border-secondary);border-radius:var(--border-radius-md);background:var(--color-background-primary);color:var(--color-text-primary)}.quick-add-input:focus{outline:none;border-color:var(--color-text-primary)}.quick-task-item{display:flex;align-items:center;gap:7px;padding:5px 0;border-bottom:.5px solid var(--color-border-tertiary);font-size:12px}.quick-task-item:last-child{border-bottom:none}.quick-task-check{width:14px;height:14px;border-radius:3px;border:1.5px solid var(--color-border-secondary);flex-shrink:0;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:9px}.quick-task-check.done{background:var(--color-background-success);border-color:var(--color-border-success);color:var(--color-text-success)}.quick-task-name{flex:1;cursor:pointer}.quick-task-name.done{text-decoration:line-through;color:var(--color-text-secondary)}.quick-task-del{font-size:11px;color:var(--color-text-tertiary);cursor:pointer;opacity:0;transition:opacity .15s;padding:0 2px}.quick-task-item:hover .quick-task-del{opacity:1}.form-field{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.form-field label{font-size:12px;color:var(--color-text-secondary)}.form-field input,.form-field textarea,.form-field select{font-family:var(--font-sans);font-size:13px;padding:7px 10px;border:.5px solid var(--color-border-secondary);border-radius:var(--border-radius-md);background:var(--color-background-primary);color:var(--color-text-primary);width:100%}.form-field input[type=checkbox],.form-field input[type=radio]{width:auto;padding:0}.form-field textarea{resize:vertical;min-height:70px}.task-check{width:16px;height:16px;border-radius:50%;border:1.5px solid var(--color-border-secondary);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:10px}.task-check.done{background:var(--color-background-success);border-color:var(--color-border-success);color:var(--color-text-success)}.task-check.in-progress{background:var(--color-background-info);border-color:var(--color-border-info)}.progress-track{background:#e0e0e0;border-radius:3px;height:6px;overflow:hidden;box-shadow:none;outline:none;border:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.progress-fill{height:100%;border-radius:0;box-shadow:none;outline:none;border:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#4a90d9;transition:width .25s ease}.badge{font-size:11px;padding:2px 8px;border-radius:12px;font-weight:500}.badge-low{background:var(--color-background-success);color:var(--color-text-success)}.badge-med{background:var(--color-background-warning);color:var(--color-text-warning)}.badge-high{background:#faeeda;color:#854f0b}.badge-critical{background:var(--color-background-danger);color:var(--color-text-danger)}.color-row{display:flex;gap:8px;flex-wrap:wrap}.color-opt{width:24px;height:24px;border-radius:50%;cursor:pointer;border:2px solid transparent}.color-opt.selected{border-color:var(--color-text-primary)}.notes-text{font-size:12px;color:var(--color-text-secondary);font-style:italic;margin-top:4px}.empty-state{text-align:center;padding:2.5rem 1rem;color:var(--color-text-secondary)}.empty-icon{font-size:28px;margin-bottom:8px}.empty-title{font-size:14px;font-weight:500;margin-bottom:4px;color:var(--color-text-primary)}.empty-sub{font-size:12px}:root{--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--color-text-primary: #1a1a1a;--color-text-secondary: #666;--color-text-tertiary: #999;--color-text-danger: #c0392b;--color-text-success: #1a7a4a;--color-text-warning: #92610a;--color-text-info: #1a5ca8;--color-bg-primary: #ffffff;--color-bg-secondary: #f5f5f5;--color-bg-danger: #fdecea;--color-bg-success: #e6f4ed;--color-bg-warning: #fef3dc;--color-bg-info: #e8f0fc;--color-border-primary: #d0d0d0;--color-border-secondary: #d8d8d8;--color-border-tertiary: #ebebeb;--color-border-danger: #e8a09a;--color-border-success: #7ec8a0;--color-border-info: #90b4e8;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 10px}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{font-family:var(--font-sans);color:var(--color-text-primary);background:#fafafa;min-height:100vh}
