:root{--hour-height: 80px}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#fff;color:#111827;overflow:hidden}button,input{font:inherit}button{border:0;background:transparent;cursor:pointer;-webkit-tap-highlight-color:transparent}.app-shell{width:100%;height:100%;display:flex;justify-content:center;background:#fff}.screen{width:100%;max-width:430px;height:100dvh;position:relative;overflow:hidden;background:#fff;padding-top:0}.topbar{height:50px;padding:12px 18px 8px;display:flex;align-items:flex-start;justify-content:space-between;position:relative;z-index:30;background:#ffffffb8;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}.topbar h1{margin:0;font-size:23px;letter-spacing:-.04em}.topbar p{margin:2px 0 0;color:#8a8a98;font-size:12px}.topbar-right{display:flex;align-items:center;gap:4px;margin-left:12px}.topbar-menu-button{width:34px;height:34px;border-radius:11px;color:#1118278f;display:flex;align-items:center;justify-content:center;flex:0 0 auto}.topbar-menu-button:active{transform:scale(.94);background:#1118270d}.day-tabs{height:56px;display:flex;gap:7px;overflow-x:auto;padding:0 10px 8px;scroll-snap-type:x mandatory;scrollbar-width:none;position:relative;z-index:30;background:#ffffffb8;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}.day-tabs::-webkit-scrollbar{display:none}.day-tab{scroll-snap-align:center;flex:0 0 45px;height:56px;border-radius:8px;background:#f5f5f6;color:#22243a;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:transform .16s,background .16s,box-shadow .16s}.day-tab.active{background:#d1d1d1;color:#22243a}.day-tab.drop-mode{transform:scale(1.02)}.day-letter{font-size:14px;font-weight:600;line-height:1}.day-date{margin-top:4px;font-size:10px;color:#77778a}.day-dots{display:flex;gap:2px;margin-top:4px}.day-dots i{width:4px;height:4px;border-radius:50%;opacity:.9}.day-dots i.done{background:#8a8a8a;opacity:.65}.day-dots i.undone{background:#111;opacity:.9}.selected-day-title{display:none}.timeline-wrap{position:absolute;top:0;right:0;bottom:0;left:0;overflow-y:auto;overflow-x:hidden;padding-top:116px;padding-bottom:24px;overscroll-behavior-y:contain;scrollbar-width:none;touch-action:pan-y;z-index:1;will-change:transform,opacity}.timeline-wrap::-webkit-scrollbar{display:none}.timeline{position:relative;height:calc(24 * var(--hour-height));margin-left:0;background:transparent;z-index:1;will-change:transform,opacity}.timeline-wrap-transition-left{animation:daySlideFromRight .26s cubic-bezier(.22,1,.36,1)}.timeline-wrap-transition-right{animation:daySlideFromLeft .26s cubic-bezier(.22,1,.36,1)}@keyframes daySlideFromRight{0%{transform:translate(60px);opacity:.25}to{transform:translate(0);opacity:1}}@keyframes daySlideFromLeft{0%{transform:translate(-60px);opacity:.25}to{transform:translate(0);opacity:1}}.hour-row{position:absolute;width:100px;text-align:center;z-index:1;left:0;right:0}.hour-row span{position:absolute;left:7px;top:-1px;font-size:20px;line-height:20px;font-weight:300;color:#dedede;z-index:0}.is-dragging .hour-row{background-image:repeating-linear-gradient(to right,#e9e4ff 0 8px,transparent 8px 16px);background-color:transparent}.task-card{position:absolute;left:32px;right:8px;border-radius:7px;padding:4px 32px 10px 31px;min-height:38px;overflow:visible;box-shadow:inset 0 0 0 1px #00000009;touch-action:pan-y;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;z-index:1;transition:transform .12s,opacity .12s,box-shadow .12s}.task-body{min-width:0;overflow:hidden}.task-card.expanded{z-index:70}.task-actions{position:absolute;right:2px;top:1px;width:166px;height:34px;display:grid;grid-template-columns:repeat(5,1fr);gap:4px;padding:4px;border-radius:10px;z-index:80}.task-action{width:28px;height:26px;border-radius:8px;color:#00000061;display:flex;align-items:center;justify-content:center}.task-action.danger{color:#ff000057}.task-action:active{transform:scale(.94)}.task-card.timed{left:8px;padding-left:31px}.task-card.untimed{left:38px;padding-left:2px}.task-card.untimed .grip{left:10px}.task-card.untimed .task-body{padding-left:10px}.task-card.untimed .task-left-time,.task-card.untimed .clock{display:none}.task-card.dragging{transform:scale(1.025);opacity:.86;z-index:50;box-shadow:0 8px 22px #1f29371f}.task-card.done .task-left-time,.task-card.done .task-category,.task-card.done .task-title{opacity:.55;text-decoration:line-through}.task-card.remove-time-preview{transform:translate(0);opacity:.92}.task-card.remove-time-preview .task-left-time,.task-card.remove-time-preview .clock{display:none}.task-left-time{position:absolute;left:6px;top:50%;width:22px;transform:translateY(-50%);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0;color:#11182785;pointer-events:none}.task-time-hour{display:block;font-size:20px;font-weight:700;line-height:18px;letter-spacing:-.04em;text-align:center}.task-time-minute{display:block;font-size:10px;font-weight:700;line-height:12px;letter-spacing:-.03em;text-align:center}.task-category{font-size:10px;font-weight:800;letter-spacing:.02em;line-height:1.1;margin-bottom:3px}.task-category-scroll{max-height:300px;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding-right:4px}.task-title{font-size:14px;font-weight:500;line-height:18px;letter-spacing:-.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.grip{position:absolute;left:21px;top:50%;transform:translateY(-50%);opacity:.3}.clock{position:absolute;right:8px;top:50%;transform:translateY(-50%);opacity:.24}.task-drag-zone{position:absolute;left:-20px;top:0;bottom:0;width:70px;display:flex;align-items:center;justify-content:flex-start;padding-left:18px;opacity:.32;touch-action:none;cursor:grab;z-index:3}.task-drag-zone:active{cursor:grabbing}.task-card.untimed .task-drag-zone{padding-left:10px}.task-card.timed .task-drag-zone{padding-left:20px}.task-delete{position:absolute;right:3px;top:3px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;opacity:0;color:#0000007a}.task-card:active .task-delete{opacity:1}.fab{position:absolute;right:18px;bottom:max(20px,env(safe-area-inset-bottom));width:58px;height:58px;border-radius:50%;background:#a9a9ad;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px #5046be40;z-index:25}.fab:active{transform:scale(.96)}.side-menu-layer{position:absolute;top:0;right:0;bottom:0;left:0;z-index:95;pointer-events:none;visibility:hidden}.side-menu-layer.open{pointer-events:auto;visibility:visible}.side-menu-visible-screen{position:absolute;left:0;top:0;bottom:0;width:30%;background:transparent;opacity:0}.side-menu-panel{position:absolute;top:0;right:0;width:70%;height:100dvh;padding:max(18px,env(safe-area-inset-top)) 16px max(18px,env(safe-area-inset-bottom));background:#ffffffeb;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);box-shadow:-18px 0 44px #1118271f;transform:translate(100%);transition:transform .22s cubic-bezier(.22,1,.36,1);touch-action:pan-y;overflow-y:auto}.side-menu-layer.open .side-menu-panel{transform:translate(0)}.side-menu-pullbar{width:28px;height:4px;border-radius:999px;background:#11182729;margin:0 0 22px auto}.side-menu-header{margin-bottom:22px}.side-menu-header span{display:block;font-size:23px;font-weight:800;letter-spacing:-.04em;color:#111827}.side-menu-header p{margin:4px 0 0;color:#9b95ac;font-size:12px}.side-menu-actions{display:grid;gap:8px}.side-menu-actions button{min-height:46px;border-radius:10px;background:#1118270b;color:#22243a;font-size:13px;font-weight:700;text-align:left;padding:0 13px}.side-menu-actions button:active{transform:scale(.98);background:#11182713}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#ffffffc7;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:flex-start;justify-content:center}.modal-backdrop.upper{z-index:120;background:#ffffff70}.modal-sheet{width:100%;max-width:430px;background:#fff;border-radius:8px 8px 0 0;min-height:100dvh;padding:22px 18px max(20px,env(safe-area-inset-bottom));box-shadow:0 -22px 50px #0000001f;position:relative;animation:sheetIn .18s ease-out}@keyframes sheetIn{0%{transform:translateY(30px);opacity:.8}to{transform:translateY(0);opacity:1}}.modal-sheet h2{margin:4px 0 24px;font-size:20px;letter-spacing:-.03em}.close{position:absolute;right:15px;top:15px;color:#9a9aa4;width:42px;height:42px;display:flex;align-items:center;justify-content:center}.field-label{display:block;margin:18px 0 8px;text-align:center;font-size:10px;color:#bbbbc2;font-weight:300}.time-picker{display:grid;gap:10px;margin:4px 0 8px}.wheel{display:flex;gap:7px;overflow-x:auto;justify-content:flex-start;scrollbar-width:none;padding:2px 0}.wheel::-webkit-scrollbar{display:none}.wheel button{min-width:42px;height:42px;border-radius:50%;color:#888;font-weight:400}.wheel button.picked{background:#efefef;color:#111827;box-shadow:inset 0 0 0 1px #efefef}.time-hint{min-height:18px;text-align:center;color:#aaaab4;font-size:11px;font-weight:300;margin-bottom:6px}.wheel.minutes button{min-width:46px}.title-input{width:100%;border:1px solid #ededf0;background:#f8f8f9;min-height:52px;padding:0 14px;border-radius:0;outline:none;text-align:left;font-size:18px;font-weight:500;color:#46464f}.title-input:focus{border-color:#ababab;background:#fff}.title-input::placeholder{color:#c9c9cf;font-weight:400;opacity:1}.category-pills{display:flex;flex-wrap:wrap;gap:8px;overflow:visible;padding-bottom:8px}.category-pills button{flex:0 0 auto;border-radius:7px;padding:10px;font-size:10px;font-weight:800;color:#565656;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;touch-action:manipulation}.category-pills button.selected{box-shadow:inset 0 0 0 2px #565656}.category-pills .new-category{display:inline-flex;gap:5px;align-items:center;background:#fff!important;border:1px dashed #ababab;color:#ababab;font-weight:300}.modal-actions{position:absolute;left:10px;right:10px;bottom:max(16px,env(safe-area-inset-bottom));display:grid;grid-template-columns:128px 1fr;gap:16px}.modal-actions.compact{position:static;margin-top:auto;padding-top:26px;grid-template-columns:1fr 1fr;gap:12px}.cancel,.save{min-height:48px;border-radius:5px;font-size:11px;font-weight:900}.cancel{background:#f1f1f2;color:#111}.save{background:#dcdcdc;color:#111}.save:not(:disabled){background:#ababab;color:#222}.save:disabled{opacity:.5}.category-sheet{min-height:100dvh;display:flex;flex-direction:column}.color-grid{display:grid;grid-template-columns:repeat(8,32px);gap:10px;justify-content:center;margin-top:10px}.color-grid button{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}.color-grid button.picked-color{box-shadow:0 0 0 3px #7c66f2,inset 0 0 0 2px #fffc}@media (min-width: 600px){body{background:#f5f5f6}.screen{box-shadow:0 0 0 1px #eee}}.day-tab.drop-target{background:#22243a;color:#fff;transform:scale(1.08)}.day-tab.drop-target .day-date{color:#ffffffbf}.week-tab{flex-basis:66px;background:#eaeaec;color:#22243a}.week-tab.active{background:#d1d1d1;color:#22243a}.week-tab.week-drop-target{background:#22243a;color:#fff;transform:scale(1.08)}.week-tab.week-drop-target .day-date{color:#ffffffc7}.week-dots i{background:#22243a}.week-dots i.done{background:#8a8a8a;opacity:.65}.week-dots i.undone{background:#111;opacity:.9}.week-tab.week-drop-target .day-dots,.day-tab.drop-target .day-dots{display:none}.task-actions{width:104px;grid-template-columns:repeat(3,1fr)}.weekly-wrap{position:absolute;top:0;right:0;bottom:0;left:0;overflow-y:auto;overflow-x:hidden;padding:116px 10px 96px;scrollbar-width:none;touch-action:pan-y;z-index:1}.weekly-wrap::-webkit-scrollbar{display:none}.weekly-title{font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#8c849b;margin:0 0 10px 4px}.weekly-list{display:flex;flex-direction:column;gap:1px}.weekly-empty{border:1px dashed #dedede;border-radius:10px;padding:18px 14px;color:#9a9aa6;font-size:13px;background:#ffffff94}.weekly-task{position:relative;min-height:46px;border-radius:8px;padding:7px 34px 8px 46px;overflow:visible;box-shadow:inset 0 0 0 1px #00000009;touch-action:pan-y;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;z-index:1;transition:transform .12s,opacity .12s,box-shadow .12s}.weekly-task.expanded{z-index:70}.weekly-task.dragging{transform:scale(1.025);opacity:.86;z-index:50;box-shadow:0 8px 22px #1f29371f}.weekly-task.done .task-category,.weekly-task.done .task-title{opacity:.55;text-decoration:line-through}.weekly-task-drag-zone{position:absolute;left:0;top:0;bottom:0;width:50px;touch-action:none;cursor:grab;z-index:3}.weekly-task-drag-zone:before{content:"";position:absolute;left:18px;top:50%;width:4px;height:18px;transform:translateY(-50%);border-radius:999px;background:currentColor;opacity:.18}.weekly-actions{top:5px}.import-export-sheet{min-height:520px;padding-bottom:max(24px,env(safe-area-inset-bottom))}.import-export-section{border:1px solid #ededf0;background:#fafafa;border-radius:12px;padding:14px;margin-bottom:12px}.import-export-title{display:flex;align-items:center;gap:8px;margin-bottom:12px;color:#22243a;font-size:13px;font-weight:900;letter-spacing:-.01em}.import-export-primary{width:100%;min-height:46px;border-radius:9px;background:#ababab;color:#222;font-size:12px;font-weight:900}.import-export-primary:active{transform:scale(.985)}.import-export-rules{margin:11px 0 0;color:#8c8c96;font-size:12px;line-height:1.42}.import-export-result,.import-export-error{border-radius:10px;padding:12px;margin-top:12px;font-size:12px;line-height:1.4}.import-export-result{background:#f1f7f1;color:#3f6f42}.import-export-error{background:#fff1f1;color:#9b2f2f}.category-screen-backdrop{z-index:100;background:#ffffffc7}.category-list-screen{display:flex;flex-direction:column;max-height:100dvh}.category-screen-scroll{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-right:2px}.category-screen-pills{display:flex;flex-wrap:wrap;gap:8px;overflow:visible;padding:4px 0 18px}.category-screen-pills button{flex:0 0 auto;border-radius:7px;padding:10px;font-size:10px;font-weight:800;color:#565656;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;touch-action:manipulation}.category-screen-pills button.inactive{opacity:.6;font-weight:300}.category-screen-pills .new-category{display:inline-flex;gap:5px;align-items:center;background:#fff!important;border:1px dashed #ababab;color:#ababab;font-weight:300}.category-show-all,.category-inactive-toggle{display:inline-flex;align-items:center;gap:8px;color:#9b9ba4;font-size:12px;font-weight:700;text-transform:lowercase}.category-show-all{margin-top:auto;padding:18px 0 max(10px,env(safe-area-inset-bottom))}.category-inactive-toggle{margin-top:18px}.category-show-all input,.category-inactive-toggle input{width:18px;height:18px;accent-color:#ababab}.modal-actions.compact.with-delete{margin-top:auto;padding-top:26px;grid-template-columns:1fr 1fr 1fr;gap:10px}.delete-category{min-height:48px;border-radius:5px;font-size:11px;font-weight:900;background:#ffe5e5;color:#9b1c1c}.delete-category:disabled{opacity:.35}
