.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}.capacity-mode-toggle{display:inline-flex;border:.5px solid var(--color-border-secondary);border-radius:20px;overflow:hidden;background:var(--color-background-secondary)}.capacity-mode-toggle button{padding:2px 9px;font-size:11px;border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:background .15s,color .15s;font-family:var(--font-sans);line-height:1.6}.capacity-mode-toggle button.active{background:var(--color-background-primary);color:var(--color-text-primary);font-weight:500;border-radius:20px;box-shadow:0 1px 3px #00000014}.capacity-mode-toggle button:hover:not(.active){color:var(--color-text-primary)}.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;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;color:var(--color-text-secondary)}.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{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:4px;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{display:flex;align-items:center;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}.autofill-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:300;display:flex;align-items:center;justify-content:center;padding:16px}.autofill-modal{background:var(--color-bg-primary);border:.5px solid var(--color-border-tertiary);border-radius:var(--radius-lg);width:100%;max-width:420px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #00000047;padding:20px;box-sizing:border-box}.autofill-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;font-size:15px;font-weight:600}.autofill-modal-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}.autofill-field{margin-bottom:18px}.autofill-label{display:block;font-size:12px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}.autofill-radio-group{display:flex;flex-direction:column;gap:6px}.autofill-radio{display:flex;align-items:center;gap:8px;font-size:13px;cursor:pointer;color:var(--color-text-primary)}.autofill-radio input{cursor:pointer;flex-shrink:0}.autofill-row{display:flex;align-items:center;gap:10px}.autofill-input{width:72px;font-size:13px;padding:5px 8px;border-radius:var(--radius-md);border:.5px solid var(--color-border-secondary);background:var(--color-bg-secondary);color:var(--color-text-primary);font-family:var(--font-sans)}.autofill-unit{font-size:12px;color:var(--color-text-secondary)}.autofill-hint{font-size:11px;color:var(--color-text-tertiary);margin-top:5px;line-height:1.4}.autofill-checkbox{display:flex;align-items:center;gap:8px;font-size:13px;cursor:pointer;color:var(--color-text-primary)}.autofill-checkbox input{cursor:pointer;flex-shrink:0}.autofill-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding-top:4px;border-top:.5px solid var(--color-border-tertiary);margin-top:4px}.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;padding:6px;min-width:36px;min-height:36px;display:flex;align-items:center;justify-content:center;opacity:.6;flex-shrink:0;color:var(--color-text-secondary)}.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;display:flex;align-items:center;color:var(--color-text-secondary)}.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;padding:6px;min-width:36px;min-height:36px;display:flex;align-items:center;justify-content:center;opacity:.55;flex-shrink:0;color:var(--color-text-secondary)}.agenda-schedule-btn-sm:active{opacity:1}.agenda-empty{padding:32px 16px;text-align:center;color:var(--color-text-tertiary);font-size:13px}.day-gcal-btn{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;padding:0;border-radius:var(--radius-sm, 4px);border:.5px solid var(--color-border-secondary);background:var(--color-bg-primary);color:var(--color-text-secondary);cursor:pointer;font-size:11px;line-height:1;flex-shrink:0;transition:background .12s,color .12s,border-color .12s;touch-action:manipulation;position:relative}.day-gcal-btn:before{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px}.planner-day-header .day-gcal-btn{flex-shrink:0}.agenda-day-header .day-gcal-btn{margin-left:6px;flex-shrink:0}.day-gcal-btn:hover:not(:disabled){background:var(--color-bg-info);border-color:var(--color-border-info);color:var(--color-text-info)}.day-gcal-btn:focus-visible{outline:2px solid var(--color-text-info);outline-offset:2px}.day-gcal-btn.done{background:var(--color-bg-success);border-color:transparent;color:var(--color-text-success);cursor:default}.day-gcal-btn.done:hover:not(:disabled){background:var(--color-bg-success);color:var(--color-text-success);cursor:pointer}.day-gcal-btn.error{background:var(--color-bg-danger);border-color:transparent;color:var(--color-text-danger)}.day-gcal-btn.error:hover:not(:disabled){background:var(--color-bg-danger);color:var(--color-text-danger);border-color:var(--color-border-danger)}.day-gcal-btn:disabled{opacity:.5;cursor:wait}.gcal-pane{max-width:760px;padding:0 0 3rem;box-sizing:border-box;width:100%}.gcal-hero{text-align:center;padding:3rem 1rem 2rem}.gcal-hero-icon{display:flex;align-items:center;justify-content:center;margin-bottom:1rem;color:var(--color-text-secondary)}.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{display:flex;align-items:center;gap:6px;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;gap:10px;margin-bottom:16px;flex-wrap:wrap}.gcal-header-actions{display:flex;gap:8px;flex-shrink:0}.gcal-connected-badge{font-size:13px;color:var(--color-text-success);font-weight:500;display:flex;align-items:center}.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-settings-panel{background:var(--color-bg-secondary);border:.5px solid var(--color-border-tertiary);border-radius:var(--radius-lg);padding:16px 18px;margin-bottom:16px}.gcal-settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 24px}@media(max-width:540px){.gcal-settings-grid{grid-template-columns:1fr}.gcal-settings-panel{padding:14px}}.gcal-section-label{font-size:11px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:7px}.gcal-setting-hint{font-weight:400;text-transform:none;letter-spacing:0}.gcal-setting-unit{font-size:12px;color:var(--color-text-secondary)}.gcal-setting-preview{font-size:11px;color:var(--color-text-tertiary);margin-top:4px}.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,.gcal-hours-row input[type=number]{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-efficiency-row{display:flex;align-items:center;gap:10px}.gcal-slider{flex:1;accent-color:var(--color-text-info)}.gcal-efficiency-val{font-size:13px;font-weight:600;min-width:36px}.gcal-settings-summary{font-size:12px;color:var(--color-text-secondary);margin-bottom:12px;line-height:1.6}.gcal-settings-edit{background:none;border:none;cursor:pointer;color:var(--color-text-info);font-size:12px;padding:0 0 0 8px;text-decoration:underline}.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-panel-tabs{display:flex;gap:0;margin-bottom:20px;border-bottom:1px solid var(--color-border-tertiary);overflow-x:auto;-webkit-overflow-scrolling:touch}.gcal-panel-tab{background:none;border:none;cursor:pointer;font-size:13px;font-weight:500;padding:9px 16px;color:var(--color-text-secondary);border-bottom:2px solid transparent;margin-bottom:-1px;border-radius:0;white-space:nowrap;display:flex;align-items:center;flex-shrink: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)}@media(max-width:400px){.gcal-panel-tab{padding:9px 12px;font-size:12px}}.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-refresh-row{display:flex;justify-content:flex-end;margin-bottom:10px}.gcal-fb-grid{display:flex;flex-direction:column;gap:6px}.gcal-fb-row{display:grid;grid-template-columns:130px 1fr 150px;align-items:center;gap:10px;padding:6px 10px;border-radius:var(--radius-md);background:var(--color-bg-secondary);font-size:12px;box-sizing:border-box}@media(max-width:540px){.gcal-fb-row{grid-template-columns:100px 1fr;grid-template-rows:auto auto;row-gap:4px}.gcal-fb-bar-wrap{grid-column:2}.gcal-fb-label{grid-column:1 / -1;flex-direction:row;justify-content:flex-start;gap:10px;text-align:left}}@media(max-width:360px){.gcal-fb-row{grid-template-columns:1fr}.gcal-fb-bar-wrap,.gcal-fb-label{grid-column:1}}.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;color:var(--color-text-primary);display:flex;align-items:center;gap:4px;flex-wrap:wrap}.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;flex-wrap:wrap}.gcal-day-label{min-width:90px;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;white-space:nowrap}.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}.gcal-delete-btn{display:inline-flex;align-items:center;justify-content:center;gap:4px;font-size:11px;padding:4px 8px;border-radius:var(--radius-md);border:.5px solid var(--color-border-secondary);background:transparent;color:var(--color-text-tertiary);cursor:pointer;min-height:28px;white-space:nowrap;transition:background .12s,color .12s,border-color .12s}.gcal-delete-btn:hover:not(:disabled){background:var(--color-bg-danger);border-color:var(--color-border-danger, transparent);color:var(--color-text-danger)}.gcal-delete-btn:disabled{opacity:.45;cursor:wait}.gcal-delete-btn.deleting{background:var(--color-bg-secondary);color:var(--color-text-tertiary);border-color:var(--color-border-tertiary);cursor:wait}.gcal-dow-row{display:flex;gap:5px;flex-wrap:wrap;margin-top:6px}.gcal-dow-btn{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);font-size:12px;font-weight:500;cursor:pointer;transition:background .15s,color .15s,opacity .15s}.gcal-dow-btn:hover{background:var(--color-bg-tertiary)}.gcal-dow-btn.gcal-dow-off{background:var(--color-bg-secondary);color:var(--color-text-tertiary);border-color:var(--color-border-tertiary);text-decoration:line-through;opacity:.7}.gcal-fb-row.gcal-day-off{opacity:.4}.gcal-off-badge{display:inline-block;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;background:var(--color-bg-tertiary);color:var(--color-text-tertiary);border-radius:var(--radius-sm, 3px);padding:1px 5px}.gcal-work-windows{display:flex;flex-direction:column;gap:6px}.gcal-work-window-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.gcal-ww-label{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--color-text-secondary)}.gcal-ww-label 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-ww-warn{font-size:11px;color:var(--color-text-warning)}.gcal-ww-remove{background:none;border:none;cursor:pointer;color:var(--color-text-tertiary);font-size:16px;line-height:1;padding:2px 4px;border-radius:var(--radius-sm, 3px);transition:color .12s}.gcal-ww-remove:hover{color:var(--color-text-danger)}.gcal-ww-add{align-self:flex-start;margin-top:2px}.gcal-write-cal-section{margin-top:20px;padding-top:16px;border-top:.5px solid var(--color-border-tertiary)}.gcal-write-cal-tip{display:flex;align-items:flex-start;gap:8px;font-size:12px;line-height:1.55;color:var(--color-text-secondary);background:var(--color-bg-info, rgba(59,130,246,.06));border:.5px solid var(--color-border-info, rgba(59,130,246,.2));border-radius:var(--radius-md);padding:9px 12px;margin-bottom:10px}.gcal-write-cal-tip-icon{font-size:13px;flex-shrink:0;margin-top:1px}.gcal-write-cal-tip a{color:var(--color-text-info);text-decoration:none;white-space:nowrap}.gcal-write-cal-tip a:hover{text-decoration:underline}.gcal-write-cal-refresh-hint{display:block;margin-top:5px;font-size:11px;color:var(--color-text-tertiary);font-style:italic}.gcal-write-cal-select{display:block;width:100%;font-size:13px;padding:6px 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;margin-bottom:8px}.gcal-write-cal-select:focus{outline:none;border-color:var(--color-border-info, #3b82f6);box-shadow:0 0 0 2px var(--color-bg-info, rgba(59,130,246,.12))}.gcal-write-cal-notice{display:flex;align-items:flex-start;gap:7px;font-size:12px;line-height:1.5;border-radius:var(--radius-md);padding:8px 11px}.gcal-write-cal-notice svg{flex-shrink:0;margin-top:1px}.gcal-write-cal-notice--warn{color:var(--color-text-warning);background:var(--color-bg-warning);border:.5px solid var(--color-border-warning, transparent)}.gcal-write-cal-notice--ok{color:var(--color-text-success);background:var(--color-bg-success);border:.5px solid var(--color-border-success, 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}[data-theme=dark]{--color-text-primary: #e8e8e8;--color-text-secondary: #a0a0a0;--color-text-tertiary: #666;--color-text-danger: #f28b82;--color-text-success: #81c995;--color-text-warning: #fdd663;--color-text-info: #8ab4f8;--color-background-primary: #1e1e1e;--color-background-secondary: #2a2a2a;--color-background-danger: #3b1f1f;--color-background-success: #1b3a26;--color-background-warning: #3b2e0a;--color-background-info: #1a2a42;--color-border-primary: #444;--color-border-secondary: #3a3a3a;--color-border-tertiary: #2e2e2e;--color-border-danger: #7a3535;--color-border-success: #2e6644;--color-border-info: #2e4a7a}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);color:var(--color-text-primary);background:#fafafa;min-height:100vh;transition:background .2s ease,color .2s ease}#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}.btn-theme-toggle{font-size:14px;padding:3px 8px;line-height:1;background:transparent;border:.5px solid var(--color-border-secondary);border-radius:var(--border-radius-md);cursor:pointer;color:var(--color-text-primary);font-family:var(--font-sans);transition:background .15s ease}.btn-theme-toggle:hover{background:var(--color-background-secondary)}.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}[data-theme=dark] .progress-track{background:#3a3a3a}.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}[data-theme=dark] .badge-high{background:#3b2a10;color:#fdd663}.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}[data-theme=dark]{--color-text-primary: #e8e8e8;--color-text-secondary: #a0a0a0;--color-text-tertiary: #666;--color-text-danger: #f28b82;--color-text-success: #81c995;--color-text-warning: #fdd663;--color-text-info: #8ab4f8;--color-bg-primary: #1e1e1e;--color-bg-secondary: #2a2a2a;--color-bg-danger: #3b1f1f;--color-bg-success: #1b3a26;--color-bg-warning: #3b2e0a;--color-bg-info: #1a2a42;--color-border-primary: #444;--color-border-secondary: #3a3a3a;--color-border-tertiary: #2e2e2e;--color-border-danger: #7a3535;--color-border-success: #2e6644;--color-border-info: #2e4a7a}*{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}[data-theme=dark] body{background:#161616}.login-page{display:grid;grid-template-columns:1fr 1fr;min-height:100vh;background:var(--color-bg-primary)}.login-hero{display:flex;align-items:center;justify-content:center;padding:4rem 3rem;background:var(--color-bg-secondary);border-right:.5px solid var(--color-border-tertiary)}.login-hero-inner{max-width:380px}.login-logo{margin-bottom:1.25rem}.login-logo-img{width:72px;height:72px;object-fit:contain;filter:none;display:block}[data-theme=dark] .login-logo-img{filter:invert(1)}.login-hero-title{font-size:30px;font-weight:700;letter-spacing:-.02em;margin-bottom:.6rem;color:var(--color-text-primary)}.login-hero-tagline{font-size:15px;line-height:1.6;color:var(--color-text-secondary);margin-bottom:2rem;max-width:340px}.login-features{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.login-feature-item{display:flex;align-items:center;gap:10px;font-size:13.5px;color:var(--color-text-secondary);line-height:1.45}.login-feature-icon{flex-shrink:0;width:22px;display:flex;align-items:center;justify-content:center;color:var(--color-text-info, #3b82f6)}.login-feature-icon svg{display:block}.login-card-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:20px}.login-card{width:100%;max-width:360px;background:var(--color-bg-secondary);border:.5px solid var(--color-border-tertiary);border-radius:var(--radius-xl, 14px);padding:28px 28px 24px;box-shadow:0 2px 16px #0000000f}[data-theme=dark] .login-card{box-shadow:0 2px 20px #0000004d}.login-card-title{font-size:18px;font-weight:650;margin-bottom:16px;color:var(--color-text-primary)}.login-mode-tabs{display:flex;gap:4px;margin-bottom:20px;background:var(--color-bg-primary);border-radius:var(--radius-md);padding:3px;border:.5px solid var(--color-border-tertiary)}.login-mode-tab{flex:1;padding:5px 8px;font-size:12.5px;font-weight:500;border:none;border-radius:calc(var(--radius-md) - 2px);background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.login-mode-tab:hover{color:var(--color-text-primary)}.login-mode-tab.active{background:var(--color-bg-secondary);color:var(--color-text-primary);box-shadow:0 1px 3px #00000014}[data-theme=dark] .login-mode-tab.active{background:var(--color-bg-tertiary);box-shadow:0 1px 4px #00000040}.login-form{display:flex;flex-direction:column;gap:14px}.login-field{display:flex;flex-direction:column;gap:5px}.login-label{font-size:12px;font-weight:500;color:var(--color-text-secondary)}.login-input{width:100%;box-sizing:border-box;font-size:14px;padding:8px 11px;border-radius:var(--radius-md);border:.5px solid var(--color-border-secondary);background:var(--color-bg-primary);color:var(--color-text-primary);transition:border-color .15s,box-shadow .15s}.login-input::placeholder{color:var(--color-text-tertiary)}.login-input:focus{outline:none;border-color:var(--color-border-info, #3b82f6);box-shadow:0 0 0 3px var(--color-bg-info, rgba(59,130,246,.1))}.login-submit{width:100%;padding:9px;font-size:14px;margin-top:2px}.login-msg{font-size:13px;padding:9px 12px;border-radius:var(--radius-md);line-height:1.45}.login-msg--error{background:var(--color-bg-danger);color:var(--color-text-danger)}.login-msg--success{background:var(--color-bg-success);color:var(--color-text-success)}.login-hint{font-size:12px;color:var(--color-text-tertiary);text-align:center;margin-top:14px;line-height:1.5;min-height:18px}.login-footer{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--color-text-tertiary);flex-wrap:wrap;justify-content:center}.login-footer a{color:var(--color-text-tertiary);text-decoration:none;transition:color .12s}.login-footer a:hover{color:var(--color-text-secondary);text-decoration:underline}.login-footer-sep{opacity:.5}@media(max-width:680px){.login-page{grid-template-columns:1fr;grid-template-rows:auto 1fr}.login-hero{padding:2.5rem 1.5rem 2rem;border-right:none;border-bottom:.5px solid var(--color-border-tertiary)}.login-hero-inner{max-width:100%}.login-hero-title{font-size:24px}.login-card-wrap{padding:2rem 1.25rem 3rem;justify-content:flex-start}.login-card{max-width:100%;padding:22px 20px 18px}}@media(max-width:400px){.login-mode-tab{font-size:11.5px;padding:5px 6px}}
