*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--bg: #f1f5f9;--bg-header: #ffffff;--bg-card: #ffffff;--bg-card-hover:#f8fafc;--bg-modal: #ffffff;--bg-input: #f8fafc;--bg-col: #f8fafc;--bg-today-col: #eef2ff;--bg-toggle: #e2e8f0;--text: #1e293b;--text-muted: #64748b;--text-light: #94a3b8;--border: #e2e8f0;--border-focus: #6366f1;--shadow-xs: 0 1px 2px rgba(0,0,0,.05);--shadow-sm: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 6px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.05);--shadow-lg: 0 10px 25px rgba(0,0,0,.12), 0 4px 10px rgba(0,0,0,.06);--accent: #6366f1;--accent-hover: #4f46e5;--accent-light: #eef2ff;--c-done: #22c55e;--c-partial: #eab308;--c-not-done: #cbd5e1;--c-late: #3b82f6;--bg-done: #f0fdf4;--bg-partial: #fefce8;--bg-not-done: #ffffff;--bg-late: #eff6ff;--t-done: #15803d;--t-partial: #92400e;--t-not-done: #475569;--t-late: #1d4ed8;--danger: #ef4444;--danger-hover: #dc2626;--danger-light: #fef2f2;--r-sm: 6px;--r: 8px;--r-lg: 12px;--r-xl: 16px;--tr: .15s ease}[data-theme=dark]{--bg: #0f172a;--bg-header: #1e293b;--bg-card: #1e293b;--bg-card-hover:#263042;--bg-modal: #1e293b;--bg-input: #0f172a;--bg-col: #131f30;--bg-today-col: #1c1f3a;--bg-toggle: #334155;--text: #f1f5f9;--text-muted: #94a3b8;--text-light: #475569;--border: #334155;--shadow-xs: 0 1px 2px rgba(0,0,0,.25);--shadow-sm: 0 1px 3px rgba(0,0,0,.3), 0 1px 2px rgba(0,0,0,.2);--shadow-md: 0 4px 6px rgba(0,0,0,.3), 0 2px 4px rgba(0,0,0,.2);--shadow-lg: 0 10px 25px rgba(0,0,0,.4), 0 4px 10px rgba(0,0,0,.25);--accent-light: #1e1f4e;--bg-done: #052e16;--bg-partial: #1c1407;--bg-not-done: #1e293b;--bg-late: #0c1d3e;--t-done: #4ade80;--t-partial: #fde047;--t-not-done: #94a3b8;--t-late: #60a5fa;--danger-light: #2d0a0a}html{font-size:16px;-webkit-text-size-adjust:100%;height:100%;overflow-x:hidden}body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;display:flex;flex-direction:column;transition:background var(--tr),color var(--tr);line-height:1.5;overflow-x:hidden}#root,.app{flex:1;display:flex;flex-direction:column}.app-header{position:sticky;top:0;z-index:100;background:var(--bg-header);border-bottom:1px solid var(--border);padding:0 24px;height:68px;display:flex;align-items:center;gap:16px;transition:background var(--tr),border-color var(--tr);box-shadow:var(--shadow-xs)}.header-left{display:flex;align-items:center;gap:8px;flex-shrink:0}.app-logo{width:38px;height:38px;background:var(--accent);color:#fff;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.app-title{font-size:18px;font-weight:700;color:var(--text);letter-spacing:-.3px}.header-nav{display:flex;align-items:center;gap:4px;flex:1;justify-content:center}.current-period{font-size:17px;font-weight:600;color:var(--text);min-width:180px;text-align:center;white-space:nowrap}.header-right{display:flex;align-items:center;gap:8px;flex-shrink:0;min-width:0}.btn-icon{width:38px;height:38px;border-radius:var(--r-sm);border:none;background:transparent;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--tr),color var(--tr);flex-shrink:0}.btn-icon:hover{background:var(--bg-toggle);color:var(--text)}.today-btn{padding:0 14px;height:34px;border-radius:var(--r-sm);border:1px solid var(--border);background:transparent;color:var(--text-muted);font-family:var(--font);font-size:14px;font-weight:500;cursor:pointer;white-space:nowrap;transition:background var(--tr),color var(--tr),border-color var(--tr)}.today-btn:hover{background:var(--bg-toggle);color:var(--text);border-color:var(--accent)}[data-theme=light] .icon-sun,[data-theme=dark] .icon-moon{display:none}[data-theme=dark] .icon-sun{display:block}.view-toggle{display:flex;background:var(--bg-toggle);border-radius:var(--r-sm);padding:2px;gap:2px}.vs,.theme-btn-mobile{display:none}.view-btn{padding:5px 14px;border-radius:5px;border:none;background:transparent;color:var(--text-muted);font-family:var(--font);font-size:14px;font-weight:500;cursor:pointer;transition:background var(--tr),color var(--tr);white-space:nowrap}.view-btn.active{background:var(--bg-modal);color:var(--text);box-shadow:var(--shadow-xs)}.btn{display:inline-flex;align-items:center;gap:7px;padding:10px 18px;border-radius:var(--r);border:none;font-family:var(--font);font-size:15px;font-weight:500;cursor:pointer;transition:background var(--tr),color var(--tr);white-space:nowrap}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--bg-toggle);color:var(--text)}.btn-secondary:hover{background:var(--border)}.btn-danger{background:var(--danger-light);color:var(--danger)}.btn-danger:hover{background:var(--danger);color:#fff}.calendar-main{flex:1;overflow:hidden;display:flex;flex-direction:column}.week-view{flex:1;display:flex;flex-direction:column;overflow:hidden}.week-pills{display:none;gap:4px;padding:8px 12px;background:var(--bg-header);border-bottom:1px solid var(--border);overflow-x:auto}.week-pill{flex-shrink:0;display:flex;flex-direction:column;align-items:center;padding:6px 10px;border-radius:var(--r);border:none;background:transparent;cursor:pointer;font-family:var(--font);transition:background var(--tr);gap:2px}.week-pill:hover{background:var(--bg-toggle)}.week-pill.active{background:var(--accent-light)}.week-pill-name{font-size:10px;font-weight:600;text-transform:uppercase;color:var(--text-muted);letter-spacing:.05em}.week-pill-num{font-size:15px;font-weight:700;color:var(--text);width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%}.week-pill.active .week-pill-num{background:var(--accent);color:#fff}.week-pill.today .week-pill-num{color:var(--accent)}.week-pill.active.today .week-pill-num{background:var(--accent);color:#fff}.week-grid{flex:1;display:grid;grid-template-columns:repeat(7,minmax(160px,1fr));overflow-x:auto;overflow-y:auto;border-top:1px solid var(--border)}.day-col{display:flex;flex-direction:column;border-right:1px solid var(--border);background:var(--bg-col);min-height:calc(100vh - 69px);transition:background var(--tr)}.day-col:last-child{border-right:none}.day-col.is-today{background:var(--bg-today-col)}.day-head{position:sticky;top:0;z-index:10;padding:14px 14px 10px;background:var(--bg-header);border-bottom:1px solid var(--border);text-align:center;transition:background var(--tr)}.day-col.is-today .day-head{background:var(--accent-light)}.day-name{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.day-num{font-size:28px;font-weight:700;line-height:1.2;margin-top:4px}.day-num-badge{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;cursor:pointer;transition:background var(--tr),color var(--tr)}.day-num-badge:hover{background:var(--bg-toggle)}.day-col.is-today .day-num-badge{background:var(--accent);color:#fff}.day-col.is-today .day-num-badge:hover{background:var(--accent-hover)}.day-col.is-today .day-num{color:var(--accent)}.day-col.ds-complete{background:#22c55e1f}.day-col.ds-partial{background:#3b82f61f}.day-col.ds-insufficient{background:#ef44441f}.day-col.ds-complete.is-today{background:#22c55e2e}.day-col.ds-partial.is-today{background:#3b82f62e}.day-col.ds-insufficient.is-today{background:#ef44442e}.day-col.ds-complete .day-head{background:#22c55e1a}.day-col.ds-partial .day-head{background:#3b82f61a}.day-col.ds-insufficient .day-head{background:#ef44441a}.tasks-list{flex:1;padding:10px 8px;display:flex;flex-direction:column;gap:7px;min-height:60px}.task-card{position:relative;background:var(--bg-card);border-radius:var(--r);border:1px solid var(--border);border-left:5px solid var(--c-not-done);padding:10px 11px 10px 13px;cursor:pointer;transition:box-shadow var(--tr),transform var(--tr),background var(--tr);display:flex;align-items:flex-start;gap:9px;box-shadow:var(--shadow-xs);-webkit-user-select:none;user-select:none}.task-card:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}.task-card:active{transform:translateY(0)}.task-card[data-status=done]{border-left-color:var(--c-done);background:var(--bg-done)}.task-card[data-status=partially_done]{border-left-color:var(--c-partial);background:var(--bg-partial)}.task-card[data-status=not_done]{border-left-color:var(--c-not-done);background:var(--bg-not-done)}.task-card[data-status=done_late]{border-left-color:var(--c-late);background:var(--bg-late)}.task-card-body{flex:1;min-width:0;text-align:center}.task-title{font-size:15px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.4}.task-card[data-status=done] .task-title{color:var(--t-done);text-decoration:line-through;opacity:.8}.task-card[data-status=partially_done] .task-title{color:var(--t-partial)}.task-card[data-status=done_late] .task-title{color:var(--t-late)}.task-desc{font-size:13px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.task-toggle-btn{flex-shrink:0;width:24px;height:24px;border-radius:50%;border:1.5px solid var(--c-not-done);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--tr),border-color var(--tr),color var(--tr);color:transparent;margin-top:1px}.task-toggle-btn:hover{background:var(--c-not-done);border-color:var(--c-not-done);color:#fff}.task-card[data-status=done] .task-toggle-btn,.task-card[data-status=done_late] .task-toggle-btn{background:var(--c-done);border-color:var(--c-done);color:#fff}.task-card[data-status=done] .task-toggle-btn:hover{background:transparent;color:transparent;border-color:var(--c-not-done)}.task-card[data-status=partially_done] .task-toggle-btn{border-color:var(--c-partial)}.task-card[data-status=done_late] .task-toggle-btn{background:var(--c-late);border-color:var(--c-late)}.add-task-btn{width:100%;margin:2px 0 8px;padding:9px 11px;border-radius:var(--r);border:1.5px dashed var(--border);background:transparent;color:var(--text-light);font-family:var(--font);font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:4px;transition:border-color var(--tr),color var(--tr),background var(--tr)}.add-task-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.sortable-ghost{opacity:.4}.sortable-drag{opacity:1!important;box-shadow:var(--shadow-md)!important;transform:rotate(1deg) scale(1.02)!important}.month-view{flex:1;display:flex;flex-direction:column;overflow:hidden}.month-weekdays{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:1px solid var(--border);background:var(--bg-header)}.month-weekday{padding:11px 4px;text-align:center;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);border-right:1px solid var(--border)}.month-weekday:last-child{border-right:none}.month-grid{flex:1;display:grid;grid-template-columns:repeat(7,1fr);grid-auto-rows:minmax(200px,1fr);overflow-y:auto;border-left:1px solid var(--border)}.month-cell{border-right:1px solid var(--border);border-bottom:1px solid var(--border);padding:10px;background:var(--bg-col);cursor:pointer;transition:background var(--tr);display:flex;flex-direction:column;gap:5px;min-height:200px}.month-cell:hover{background:var(--bg-card-hover)}.month-cell.is-today{background:var(--bg-today-col)}.month-cell.other-month{opacity:.45}.month-cell.ds-complete{background:#22c55e1f}.month-cell.ds-partial{background:#3b82f61f}.month-cell.ds-insufficient{background:#ef44441f}.month-cell.ds-complete.is-today{background:#22c55e2e}.month-cell.ds-partial.is-today{background:#3b82f62e}.month-cell.ds-insufficient.is-today{background:#ef44442e}.month-cell-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:2px}.month-day-num{font-size:15px;font-weight:600;color:var(--text-muted);width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;line-height:1;cursor:pointer;transition:background var(--tr)}.month-day-num:hover{background:var(--bg-toggle)}.month-cell.is-today .month-day-num{background:var(--accent);color:#fff}.month-add-btn{width:20px;height:20px;border-radius:50%;border:none;background:transparent;color:var(--text-light);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--tr),color var(--tr),background var(--tr)}.month-cell:hover .month-add-btn{opacity:1}.month-add-btn:hover{background:var(--accent);color:#fff}.month-task-bar{display:flex;align-items:center;gap:9px;padding:8px 12px;border-radius:var(--r-sm);font-size:15px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;transition:opacity var(--tr)}.month-task-bar:hover{opacity:.8}.month-task-bar[data-status=done]{background:var(--bg-done);color:var(--t-done)}.month-task-bar[data-status=partially_done]{background:var(--bg-partial);color:var(--t-partial)}.month-task-bar[data-status=not_done]{background:var(--bg-not-done);color:var(--t-not-done);border:1px solid var(--border)}.month-task-bar[data-status=done_late]{background:var(--bg-late);color:var(--t-late)}.month-bar-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.month-task-bar[data-status=done] .month-bar-dot{background:var(--c-done)}.month-task-bar[data-status=partially_done] .month-bar-dot{background:var(--c-partial)}.month-task-bar[data-status=not_done] .month-bar-dot{background:var(--c-not-done)}.month-task-bar[data-status=done_late] .month-bar-dot{background:var(--c-late)}.month-more{font-size:13px;color:var(--text-muted);padding:3px 12px;font-weight:500}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:200;display:flex;align-items:center;justify-content:center;padding:16px;opacity:0;pointer-events:none;transition:opacity .2s ease}.modal-overlay.open{opacity:1;pointer-events:auto}.modal{background:var(--bg-modal);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);width:100%;max-width:520px;display:flex;flex-direction:column;transform:scale(.95) translateY(8px);transition:transform .2s ease,background var(--tr);max-height:calc(100vh - 48px);overflow:hidden}.modal-overlay.open .modal{transform:scale(1) translateY(0)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:22px 22px 0}.modal-heading{font-size:20px;font-weight:700;color:var(--text)}.modal-body{padding:20px 22px;display:flex;flex-direction:column;gap:18px;overflow-y:auto}.modal-footer{display:flex;align-items:center;justify-content:space-between;padding:14px 22px 20px;border-top:1px solid var(--border);gap:8px}.modal-footer-actions{display:flex;gap:8px}.form-group{display:flex;flex-direction:column;gap:5px}.form-label{font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.form-input,.form-textarea{padding:11px 14px;border-radius:var(--r);border:1.5px solid var(--border);background:var(--bg-input);color:var(--text);font-family:var(--font);font-size:16px;transition:border-color var(--tr),background var(--tr);outline:none;width:100%}.form-input:focus,.form-textarea:focus{border-color:var(--border-focus);background:var(--bg-modal)}.form-textarea{resize:vertical;min-height:72px}.form-input[type=date]{cursor:pointer}.status-selector{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}.status-opt{display:flex;align-items:center;gap:10px;padding:11px 14px;border-radius:var(--r);border:1.5px solid var(--border);background:var(--bg-input);cursor:pointer;font-family:var(--font);font-size:14px;font-weight:500;color:var(--text-muted);transition:border-color var(--tr),color var(--tr),background var(--tr)}.status-opt:hover{border-color:var(--accent);color:var(--text)}.status-opt.selected{border-color:var(--accent);background:var(--accent-light);color:var(--text)}.status-swatch{width:10px;height:10px;border-radius:50%;flex-shrink:0}.status-swatch.done{background:var(--c-done)}.status-swatch.partially_done{background:var(--c-partial)}.status-swatch.not_done{background:var(--c-not-done)}.status-swatch.done_late{background:var(--c-late)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-light)}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:24px}.login-card{background:var(--bg-modal);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);border:1px solid var(--border);padding:40px 36px;width:100%;max-width:360px;display:flex;flex-direction:column;align-items:center;gap:8px}.login-logo{width:52px;height:52px;background:var(--accent);color:#fff;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;margin-bottom:4px}.login-title{font-size:22px;font-weight:700;color:var(--text);letter-spacing:-.3px}.login-subtitle{font-size:14px;color:var(--text-muted);text-align:center;margin-bottom:8px}.login-form{width:100%;display:flex;flex-direction:column;gap:10px;margin-top:8px}.login-input{width:100%;font-size:16px}.login-input-error{border-color:var(--danger)!important}.login-error{font-size:13px;color:var(--danger);text-align:center}.login-btn{width:100%;justify-content:center;font-size:15px;padding:12px}.loading-state{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:14px;gap:8px}@media (max-width: 900px){.week-grid{grid-template-columns:repeat(7,minmax(110px,1fr))}}@media (max-width: 720px){.app-header{padding:0 12px;gap:8px}.header-nav{gap:2px}.current-period{min-width:120px;font-size:15px}}@media (max-width: 560px){.vl{display:none}.vs{display:inline}.view-btn{padding:5px 9px}.current-period{min-width:90px;font-size:14px}}@media (max-width: 640px){.app-title,.today-btn{display:none}.current-period{min-width:90px}.theme-btn-desktop{display:none}.theme-btn-mobile{display:flex}.app-logo,.logout-btn{display:none}.week-pills{display:flex}.week-grid{grid-template-columns:1fr;overflow-x:hidden;border-top:none}.day-col{min-height:auto}.day-col.mobile-hidden{display:none}.day-col.mobile-visible{display:flex}.modal{max-width:100%;border-radius:var(--r-lg) var(--r-lg) 0 0}.modal-overlay{align-items:flex-end;padding:0}.modal-overlay.open .modal{transform:translateY(0)}.modal-overlay .modal{transform:translateY(20px)}.status-selector{grid-template-columns:repeat(2,1fr)}.month-grid{grid-auto-rows:minmax(130px,1fr)}.month-cell{padding:6px;gap:4px;min-height:130px}.month-task-bar{font-size:11px;padding:4px 7px}}@media (max-width: 400px){.view-btn{padding:4px 6px;font-size:11px}.app-logo{width:28px;height:28px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.task-card{animation:fadeIn .15s ease forwards}
