:root{font-family:Inter,system-ui,-apple-system,sans-serif;color:#1a2e1a;--keyboard-inset: 0px;background:radial-gradient(circle at bottom,#a5d6a7,#b9d4a0 25%,#9ac47e 55%,#aecb9f 75%,#1a6b3c);min-height:100svh}*{box-sizing:border-box;-webkit-user-select:none;user-select:none}html{width:100%;overflow:hidden}body{margin:0;height:100svh;position:fixed;width:100%;overflow-y:scroll;-webkit-overflow-scrolling:touch}@media(hover:hover)and (pointer:fine){button,[role=button],a[href],input[type=button],input[type=submit],input[type=reset],summary,.modal-backdrop,.drawer-backdrop{cursor:pointer}}.app{min-height:100%;display:flex;flex-direction:column;padding:16px 14px calc(104px + env(safe-area-inset-bottom))}.pull-refresh-indicator{position:fixed;top:0;left:50%;width:44px;height:44px;border-radius:999px;display:flex;align-items:center;justify-content:center;background:#e8f5e9;box-shadow:0 3px 10px #1a6b3c40;z-index:65;pointer-events:none;transition:transform .12s ease-out}.pull-refresh-indicator__ring{width:26px;height:26px;border-radius:999px;border:3px solid rgba(26,107,60,.25);border-top-color:#1a6b3c}.pull-refresh-indicator--active .pull-refresh-indicator__ring{animation:spin .8s linear infinite}.app__header{display:flex;flex-direction:column;gap:16px;color:#f4f7f2;margin-bottom:8px}.header-card{border-radius:18px;padding:10px 2px;display:grid;gap:8px;min-width:0}.title-row{display:flex;align-items:center;justify-content:space-between;gap:8px;min-width:0}.title-button{margin:0;font-size:24px;font-weight:500;border:none;padding:0;background:transparent;color:inherit;text-align:left;max-width:100%;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.title-edit{display:grid;width:100%;min-width:0;grid-template-columns:minmax(0,1fr);align-items:center}.title-edit input{width:100%;min-width:0;padding:8px 12px;border-radius:14px;border:1px solid rgba(255,255,255,.55);background:#1a2e1a47;color:#f4f7f2;font-size:16px;outline:none}.title-edit input::placeholder{color:#f4f7f2bf}.title-edit input:focus{border-color:#fffffff2;box-shadow:0 0 0 2px #fff3}.todo-list{display:flex;flex-direction:column;gap:4px;margin-top:8px;list-style:none;padding:0}.todo-item{display:flex;align-items:center;gap:14px;background:#ffffffb8;border-radius:14px;padding:14px 16px;transition:transform .11s ease,background 80ms ease;touch-action:manipulation}.todo-item--pressing{transform:scale(.98);background:#ffffff8c}.todo-item--exiting{animation:todo-slide-out .24s ease-in forwards;pointer-events:none}@keyframes todo-slide-out{0%{transform:translate(0) scaleY(1);opacity:1;max-height:80px}40%{transform:translate(12px) scaleY(.9);opacity:.6}to{transform:translate(48px) scaleY(.5);opacity:0;max-height:0;padding-top:0;padding-bottom:0;margin-bottom:0}}@media(prefers-reduced-motion:reduce){.todo-item,.todo-item--exiting{animation:none;transition:none}}.todo-item__checkbox{flex-shrink:0;width:26px;height:26px;display:flex;align-items:center;justify-content:center;color:#1a6b3c}.todo-item__checkbox svg{width:26px;height:26px}.todo-item__content{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.todo-item__title{font-size:16px;font-weight:500;color:#1a2e1a;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.todo-item__meta{display:flex;flex-wrap:wrap;gap:8px}.todo-item__due-date,.todo-item__assigned-to{font-size:12px;color:#4e7a5e;font-weight:500}.todo-item__due-date--overdue{color:#c0392b}.todo-item__recurrence{display:inline-flex;align-items:center;color:#4e7a5e}.undo-toast-stack{position:fixed;left:50%;bottom:calc(68px + env(safe-area-inset-bottom));transform:translate(-50%);width:min(420px,calc(100% - 24px));display:flex;flex-direction:column;gap:8px;z-index:40;pointer-events:none}.undo-toast{background:#1a2e1af2;color:#f4f7f2;border-radius:14px;padding:12px 14px;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;box-shadow:0 10px 24px #00000040;pointer-events:auto}.undo-toast__text{min-width:0;flex:1;overflow-wrap:anywhere;word-break:break-word}.undo-toast__action{border:none;border-radius:999px;padding:6px 12px;background:#ffffff2e;color:#f4f7f2;font-weight:600;flex-shrink:0}.app-toast-stack{position:fixed;left:50%;bottom:calc(126px + env(safe-area-inset-bottom));transform:translate(-50%);width:min(460px,calc(100% - 24px));display:flex;flex-direction:column;gap:8px;z-index:46;pointer-events:none}.app-toast{pointer-events:auto;border-radius:14px;padding:10px 12px;color:#f4f7f2;display:flex;align-items:center;justify-content:space-between;gap:10px;background:#1a2e1af2}.app-toast--error{background:#6e1621f2}.app-toast__text{min-width:0;overflow-wrap:anywhere}.app-toast__close{border:none;border-radius:999px;padding:5px 10px;background:#ffffff2e;color:inherit}.bottom-bar{position:fixed;bottom:0;left:0;right:0;padding:6px 18px calc(10px + env(safe-area-inset-bottom));background:radial-gradient(circle at 50% 2px,transparent 33px,#1a6b3c 34px);display:flex;justify-content:space-between;align-items:center;gap:16px;height:calc(56px + env(safe-area-inset-bottom));overflow:visible;z-index:10}.fab{width:60px;height:60px;border-radius:50%;background:#1a6b3c;font-size:28px;color:#fff;box-shadow:0 10px 18px #0003;position:absolute;left:50%;transform:translate(-50%,-24px);display:inline-flex;align-items:center;justify-content:center;border:4px solid transparent}.bottom-icon{width:40px;height:40px;border-radius:20px;border:none;background:transparent;color:#f4f7f2;font-size:20px;display:inline-flex;align-items:center;justify-content:center}.bottom-icon svg,.fab svg{width:22px;height:22px}.bottom-bar__actions-right{display:inline-flex;align-items:center;gap:4px}.bottom-bar__status{min-width:24px}.header-status{display:inline-flex;align-items:center;justify-content:center;min-width:20px;min-height:20px}.connection-spinner{width:15px;height:15px;border-radius:999px;border:2px solid rgba(255,255,255,.5);border-top-color:#f4f7f2;animation:spin .8s linear infinite}.connection-icon{display:inline-flex;width:22px;height:22px}.connection-icon--offline{color:#f6f294}.connection-icon__image{width:100%;height:100%;display:block}.connection-badge{position:relative;display:inline-flex;align-items:center;justify-content:center;border:none;background:transparent;padding:0;color:inherit}.connection-badge__tooltip{position:absolute;right:0;bottom:calc(100% + 8px);min-width:180px;max-width:220px;border-radius:10px;background:#1a2e1af2;color:#f4f7f2;font-size:12px;line-height:1.35;padding:8px 10px;text-align:left;opacity:0;visibility:hidden;transform:translateY(4px);transition:opacity .16s ease,transform .16s ease,visibility .16s ease;pointer-events:none;z-index:1}.connection-badge__tooltip--visible{opacity:1;visibility:visible;transform:translateY(0)}.modal-backdrop{position:fixed;inset:0;background:#05120a99;display:flex;align-items:center;justify-content:center;padding:24px 20px calc(80px + env(safe-area-inset-bottom) + var(--keyboard-inset));transition:padding-bottom .22s ease;z-index:20}.modal{width:min(520px,100%);background:#f4f7f2;border-radius:28px;padding:28px 26px 24px;box-shadow:0 24px 48px #00000040;display:flex;flex-direction:column;gap:18px;max-height:calc(100svh - 48px - var(--keyboard-inset));overflow-y:auto;transition:max-height .22s ease}@media(prefers-reduced-motion:reduce){.modal-backdrop,.modal{transition:none}}.modal__header{display:flex;align-items:center;justify-content:space-between}.modal__header h2{margin:0;font-size:24px;font-weight:500;color:#1a2e1a}.modal__body{display:flex;flex-direction:column;gap:18px}.modal__field{display:flex;flex-direction:column;gap:6px}.modal__field label{font-size:13px;color:#4e7a5e}.modal__body input{border:none;border-bottom:1px solid rgba(26,46,26,.4);padding:6px 2px 8px;font-size:16px;background:transparent;color:#1a2e1a;outline:none;appearance:none;-webkit-appearance:none}.modal__body input[type=date]{-webkit-user-select:text;user-select:text}.modal__body textarea{border:none;border-bottom:1px solid rgba(26,46,26,.4);padding:6px 2px 8px;font-size:16px;background:transparent;color:#1a2e1a;outline:none;appearance:none;-webkit-appearance:none;resize:vertical;font-family:inherit;-webkit-user-select:text;user-select:text}.modal__body select{border:none;border-bottom:1px solid rgba(26,46,26,.4);padding:6px 28px 8px 2px;font-size:16px;background:transparent;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' stroke='%231a2e1a' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;background-size:12px;color:#1a2e1a;outline:none;appearance:none;-webkit-appearance:none}.modal__body .recurrence-input__number{width:60px}.settings-language-select{border:none;border-bottom:1px solid rgba(26,46,26,.4);padding:6px 2px 8px;font-size:16px;background:transparent;color:#1a2e1a;outline:none;appearance:none;-webkit-appearance:none;-moz-appearance:none}.modal__actions{display:flex;justify-content:space-between;gap:20px;margin-top:6px}.primary-button{border:none;border-radius:999px;background:#1a6b3c;color:#f4f7f2;padding:10px 20px;font-size:15px;font-weight:500}.primary-button:disabled{opacity:.45}.text-button{border:none;background:transparent;color:#1a6b3c;font-size:16px;font-weight:500;padding:6px 4px}.text-button--danger{color:#d32f2f;font-size:16px}.add-dialog{align-items:flex-start;padding-top:60px}.add-dialog .modal{background:#0a1e0fc7;border-radius:12px;width:min(460px,100%);padding:16px;gap:12px}.add-dialog .add-panel input{width:100%;padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.8);background:transparent;color:#fff;font-size:16px;-webkit-user-select:text;user-select:text;appearance:none;-webkit-appearance:none}.add-dialog .add-panel input[type=date]{color-scheme:dark}.add-dialog .add-panel input::placeholder{color:#ffffffb3}.add-dialog .add-panel textarea{width:100%;padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.8);background:transparent;color:#fff;font-size:16px;-webkit-user-select:text;user-select:text;appearance:none;-webkit-appearance:none;resize:vertical;font-family:inherit}.add-dialog .add-panel textarea::placeholder{color:#ffffffb3}.add-dialog .add-panel select{padding:10px 32px 10px 12px;border-radius:8px;border:1px solid rgba(255,255,255,.8);background:transparent;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' stroke='%23ffffff' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;background-size:12px;color:#fff;font-size:14px;appearance:none;-webkit-appearance:none;outline:none}.add-dialog .add-panel .recurrence-input__number{width:60px}.add-dialog__actions{display:flex;justify-content:flex-end}.add-dialog__field{display:flex;flex-direction:column;gap:4px;margin-top:10px}.add-dialog__field label{font-size:12px;color:#ffffffb3}.assignee-suggestions{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}.assignee-suggestions__option{border:1px solid rgba(26,46,26,.35);background:#1a6b3c14;color:#1a2e1a;border-radius:999px;padding:4px 10px;font-size:12px}.assignee-suggestions__option--active{background:#1a6b3c;border-color:#1a6b3c;color:#f4f7f2}.add-dialog .assignee-suggestions__option{border-color:#fff9;background:#ffffff29;color:#fff}.add-dialog .assignee-suggestions__option--active{background:#fff;border-color:#fff;color:#0f2b18}.add-dialog .primary-button{background:#1a6b3c;color:#f4f7f2}.drawer-edge-swipe-zone{position:fixed;inset:0 auto 0 0;width:28px;z-index:29;touch-action:none}.drawer-overlay{position:fixed;inset:0;pointer-events:none;z-index:30;opacity:0;visibility:hidden;transition:opacity .2s ease .3s,visibility 0s linear .5s}.drawer-overlay--open{pointer-events:auto;opacity:1;visibility:visible;transition:opacity .2s ease 0s,visibility 0s linear 0s}.drawer-backdrop{position:absolute;inset:0;background:#00000073}.drawer{position:absolute;top:0;bottom:0;left:0;width:min(320px,80vw);background:#f0f7f1;transform:translate(-100%);transition:transform .26s ease-in;display:flex;flex-direction:column;touch-action:none}.drawer--open{transform:translate(0);transition-timing-function:ease-out}.drawer--dragging{transition:none}.drawer__header{background:#1a6b3c;color:#fff;padding:24px 18px;font-size:22px;font-weight:500;min-height:140px;display:flex;align-items:flex-start;justify-content:flex-start}.drawer__section{padding:18px;flex:1;overflow-y:auto}.drawer__title{margin:0 0 12px;color:#4e7a5e;font-weight:500;font-size:16px}.drawer__list{display:flex;flex-direction:column;gap:14px}.drawer__item{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.drawer__item-button{flex:1;display:flex;align-items:flex-start;gap:12px;background:transparent;border:none;text-align:left;font-size:16px;color:#1a2e1a;padding:4px 6px 4px 0;min-width:0}.drawer__item-button--active{font-weight:600}.drawer__item-icon{width:24px;height:24px;color:#6a9c7a;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.drawer__item-icon svg{width:22px;height:22px}.drawer__item-copy{display:grid;gap:3px;min-width:0;flex:1}.drawer__item-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.drawer__item-meta{font-size:12px;color:#67816b;white-space:normal;overflow-wrap:anywhere;line-height:1.3}.drawer__delete{width:32px;height:32px;border:none;background:#0000000d;color:#6a9c7a;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;margin-top:2px;flex-shrink:0}.drawer__delete svg{width:22px;height:22px}.drawer__delete:disabled{opacity:.45}.drawer__delete--confirm{width:auto;min-width:40px;padding:0 8px;font-size:12px;font-weight:700;color:#a61f2d}.drawer__delete-hint{margin:-4px 0 0;font-size:12px;color:#4e7a5e}.drawer__new{border:none;background:transparent;display:flex;align-items:center;gap:12px;font-size:16px;color:#1a2e1a;padding:6px 0}.drawer__settings{border:none;background:#1a6b3cd9;color:#fff;padding:14px 24px;display:flex;align-items:center;justify-content:space-between;font-size:16px}.drawer__settings .drawer__item-icon{color:#fff}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:420px){.app{padding-left:10px;padding-right:10px}.title-button{font-size:21px}.title-edit{grid-template-columns:minmax(0,1fr)}.drawer{width:min(336px,88vw)}}.recurrence-input__controls{display:flex;flex-direction:column;gap:8px;margin-top:4px}.recurrence-input__toggle-label{display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:#4e7a5e;-webkit-user-select:none;user-select:none}.recurrence-input__toggle-checkbox{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.recurrence-input__toggle-track{display:inline-flex;align-items:center;width:36px;height:20px;border-radius:999px;background:#1a2e1a2e;flex-shrink:0;transition:background .15s ease;position:relative}.recurrence-input__toggle-knob{position:absolute;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #00000040;transition:left .15s ease,background .15s ease}.recurrence-input__toggle-checkbox:checked+.recurrence-input__toggle-track{background:#1a6b3c}.recurrence-input__toggle-checkbox:checked+.recurrence-input__toggle-track .recurrence-input__toggle-knob{left:18px}.recurrence-input__toggle-checkbox:focus-visible+.recurrence-input__toggle-track{outline:2px solid #1a6b3c;outline-offset:2px}.add-dialog .recurrence-input__toggle-label{color:#ffffffd9}.add-dialog .recurrence-input__toggle-track{background:#ffffff40}.add-dialog .recurrence-input__toggle-checkbox:checked+.recurrence-input__toggle-track{background:#4caf7d}.add-dialog .recurrence-input__toggle-knob{background:#fff}.add-dialog__field--recurrence,.modal__field--recurrence{margin-top:-6px}.recurrence-input__row{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.recurrence-input__number{width:60px}.recurrence-input__anchor{display:flex;gap:12px;font-size:13px}.recurrence-input__anchor label{display:flex;align-items:center;gap:4px;cursor:pointer}.recurrence-input__anchor input[type=radio]{width:18px;height:18px;margin:0;flex-shrink:0;accent-color:#1a6b3c;appearance:auto;-webkit-appearance:auto;border:none}.add-dialog .recurrence-input__anchor input[type=radio]{appearance:auto;-webkit-appearance:auto;border:none;accent-color:#1a6b3c}
