*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.absolute{position:absolute}.flex{display:flex}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.uppercase{text-transform:uppercase}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}:root,[data-theme=dark]{--bg-app: #0B0F14;--bg-surface: #111823;--bg-raised: #1A2230;--bg-sunken: #060A0F;--border-soft: #1F2A3A;--border-hard: #2D3B50;--border-focus: #FB923C;--fg-primary: #E6EDF3;--fg-secondary: #9BA7B7;--fg-tertiary: #5B6776;--fg-disabled: #3A4658;--accent: #FB923C;--accent-hover: #FDBA74;--accent-ink: #2A1508;--accent-soft: rgba(251, 146, 60, .14);--accent-rgb: 251, 146, 60;--red: #F87171;--red-soft: rgba(248, 113, 113, .12);--amber: #FBBF24;--amber-soft: rgba(251, 191, 36, .12);--green: #34D399;--green-soft: rgba(52, 211, 153, .12);--violet: #A78BFA;--violet-soft: rgba(167, 139, 250, .12);--teal: #2DD4BF;--teal-soft: rgba(45, 212, 191, .12);--indigo: #818CF8;--indigo-soft: rgba(129, 140, 248, .12);--grid-line: rgba(251, 146, 60, .025);--grid-major: rgba(251, 146, 60, .05)}[data-theme=light]{--bg-app: #F6F7F9;--bg-surface: #FFFFFF;--bg-raised: #F0F3F7;--bg-sunken: #EDF0F4;--border-soft: #E4E8EE;--border-hard: #CBD3DE;--border-focus: #EA580C;--fg-primary: #0B1220;--fg-secondary: #4B5566;--fg-tertiary: #8693A5;--fg-disabled: #BFC7D3;--accent: #EA580C;--accent-hover: #C2410C;--accent-ink: #FFFFFF;--accent-soft: rgba(234, 88, 12, .1);--accent-rgb: 234, 88, 12;--red: #DC2626;--red-soft: rgba(220, 38, 38, .08);--amber: #D97706;--amber-soft: rgba(217, 119, 6, .08);--green: #059669;--green-soft: rgba(5, 150, 105, .08);--violet: #7C3AED;--violet-soft: rgba(124, 58, 237, .08);--teal: #0D9488;--teal-soft: rgba(13, 148, 136, .08);--indigo: #4F46E5;--indigo-soft: rgba(79, 70, 229, .08);--grid-line: rgba(234, 88, 12, .03);--grid-major: rgba(234, 88, 12, .06)}:root{--font-sans: "Inter", "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", "Yu Gothic UI", system-ui, sans-serif;--font-mono: "JetBrains Mono", "SF Mono", "Menlo", "Consolas", monospace;--fs-micro: 10px;--fs-xs: 11px;--fs-sm: 12px;--fs-base: 13px;--fs-md: 14px;--fs-lg: 16px;--fs-xl: 20px;--fs-2xl: 28px;--fs-3xl: 40px;--fw-regular: 400;--fw-medium: 500;--fw-semi: 600;--fw-bold: 700;--lh-tight: 1.2;--lh-snug: 1.35;--lh-normal: 1.5;--r-sm: 4px;--r-md: 6px;--r-lg: 8px;--r-xl: 10px;--r-pill: 999px;--s-0: 0;--s-1: 4px;--s-2: 8px;--s-3: 12px;--s-4: 16px;--s-5: 20px;--s-6: 24px;--s-8: 32px;--s-10: 40px;--s-12: 48px;--ease-out: cubic-bezier(.2, .8, .2, 1);--dur-fast: .12s;--dur-med: .22s;--z-sticky: 10;--z-overlay: 50;--z-modal: 100}*{box-sizing:border-box}html,body,#root{height:100%}html,body{margin:0;padding:0;overflow-x:hidden;max-width:100vw}body{font-family:var(--font-sans);font-size:var(--fs-base);color:var(--fg-primary);background:var(--bg-app);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;padding:0}input,select,textarea{font-family:inherit;color:inherit}ul,ol{list-style:none;margin:0;padding:0}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}.mono{font-family:var(--font-mono)}.tabular{font-variant-numeric:tabular-nums}.uppercase-label{font-family:var(--font-mono);font-size:var(--fs-micro);letter-spacing:.08em;text-transform:uppercase;color:var(--fg-tertiary)}.app-root{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-app)}.app-header{height:52px;background:var(--bg-surface);border-bottom:1px solid var(--border-soft);display:flex;align-items:center;padding:0 16px;gap:16px;flex-shrink:0;position:sticky;top:0;z-index:var(--z-sticky)}.logo{font-family:var(--font-mono);font-size:13px;font-weight:var(--fw-bold);letter-spacing:.06em;color:var(--fg-primary);display:flex;align-items:center;gap:6px;flex-shrink:0}.logo-mark{width:22px;height:22px;border:1px solid var(--accent);border-radius:3px;display:inline-flex;align-items:center;justify-content:center;font-size:10px;color:var(--accent);font-weight:var(--fw-bold);background:var(--accent-soft)}.logo .tm{font-size:9px;color:var(--fg-tertiary);margin-left:2px}.tabs{display:flex;gap:2px;background:var(--bg-raised);border:1px solid var(--border-soft);border-radius:var(--r-md);padding:2px}.tab{font-family:var(--font-mono);font-size:11px;font-weight:var(--fw-medium);letter-spacing:.04em;padding:5px 12px;border-radius:4px;color:var(--fg-secondary);display:flex;align-items:center;gap:6px;transition:all var(--dur-fast) var(--ease-out)}.tab:hover{color:var(--fg-primary)}.tab.active{background:var(--accent);color:var(--accent-ink)}.tab .count{font-size:10px;opacity:.7;font-variant-numeric:tabular-nums}.tab.active .count{opacity:1}.header-actions{margin-left:auto;display:flex;align-items:center;gap:4px}.icon-btn{width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--r-sm);color:var(--fg-secondary);transition:all var(--dur-fast) var(--ease-out);font-size:14px}.icon-btn:hover{background:var(--bg-raised);color:var(--fg-primary)}.user-email{font-family:var(--font-mono);font-size:10px;color:var(--fg-tertiary);letter-spacing:.02em;padding:0 4px}.btn-signout{font-family:var(--font-mono);font-size:11px;font-weight:var(--fw-semi);letter-spacing:.08em;text-transform:uppercase;padding:6px 12px;border-radius:var(--r-sm);color:var(--fg-secondary);border:1px solid var(--border-hard);background:var(--bg-raised);transition:all var(--dur-fast) var(--ease-out);white-space:nowrap}.btn-signout:hover{color:var(--red);border-color:var(--red);background:var(--red-soft)}.app-body{flex:1;display:flex;min-height:0;overflow:hidden}.content{flex:1;padding:20px 28px 40px;overflow-y:auto}.btn-primary{background:var(--accent);color:var(--accent-ink);font-family:var(--font-mono);font-size:11px;font-weight:var(--fw-semi);letter-spacing:.08em;text-transform:uppercase;padding:7px 14px;border-radius:var(--r-sm);transition:all var(--dur-fast) var(--ease-out);display:inline-flex;align-items:center;justify-content:center;gap:6px;white-space:nowrap}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-primary .keycap{font-family:var(--font-mono);font-size:9px;padding:1px 4px;background:#00000038;border-radius:2px;letter-spacing:.04em}.btn-ghost{font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;padding:6px 10px;border-radius:var(--r-sm);color:var(--fg-secondary);transition:all var(--dur-fast) var(--ease-out);border:1px solid transparent}.btn-ghost:hover:not(:disabled){background:var(--bg-raised);color:var(--fg-primary)}.btn-ghost:disabled{opacity:.3;cursor:not-allowed}.btn-ghost.bordered{border-color:var(--border-soft)}.btn-ghost.danger:hover:not(:disabled){color:var(--red);border-color:var(--red);background:var(--red-soft)}.btn-danger{font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;padding:6px 10px;border-radius:var(--r-sm);color:var(--red);border:1px solid var(--red);transition:all var(--dur-fast) var(--ease-out);background:transparent}.btn-danger:hover:not(:disabled){background:var(--red-soft)}.keycap{font-family:var(--font-mono);font-size:9px;padding:1px 5px;border:1px solid var(--border-hard);border-bottom-width:2px;border-radius:3px;color:var(--fg-tertiary);background:var(--bg-raised);letter-spacing:.04em}.composer{background:var(--bg-surface);border:1px solid var(--border-soft);border-radius:var(--r-md);padding:3px;display:flex;align-items:center;gap:3px;margin-bottom:14px;transition:border-color var(--dur-fast) var(--ease-out)}.composer:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.composer input[type=text],.composer textarea{flex:1;background:transparent;border:none;outline:none;padding:8px 10px;font-size:var(--fs-md);color:var(--fg-primary);min-width:0;resize:none}.composer input::-moz-placeholder,.composer textarea::-moz-placeholder{color:var(--fg-tertiary)}.composer input::placeholder,.composer textarea::placeholder{color:var(--fg-tertiary)}.composer .seg{display:flex;align-items:center;border-left:1px solid var(--border-soft);padding-left:4px;gap:4px;flex-shrink:0}.pri-toggle{display:flex;gap:2px;background:var(--bg-raised);border-radius:var(--r-sm);padding:2px}.pri-toggle button{font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;padding:4px 8px;border-radius:3px;color:var(--fg-tertiary);transition:all var(--dur-fast) var(--ease-out)}.pri-toggle button:hover{color:var(--fg-primary)}.pri-toggle button.sel-high{background:var(--red-soft);color:var(--red)}.pri-toggle button.sel-medium{background:var(--amber-soft);color:var(--amber)}.pri-toggle button.sel-low{background:var(--bg-app);color:var(--fg-secondary)}.folder-picker,.select{font-family:var(--font-mono);font-size:11px;padding:6px 8px;background:var(--bg-raised);border:1px solid var(--border-soft);border-radius:var(--r-sm);color:var(--fg-secondary);max-width:140px;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;outline:none}.folder-picker:focus,.select:focus{border-color:var(--accent)}.toolbar{display:flex;align-items:center;gap:10px;margin-bottom:12px;min-height:28px}.toolbar .spacer{flex:1}.folder-group{margin-bottom:14px}.folder-head{display:flex;align-items:center;gap:6px;padding:6px 4px;margin-bottom:4px;font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-tertiary);cursor:pointer;border-bottom:1px dashed var(--border-soft);transition:background-color var(--dur-fast) var(--ease-out);border-radius:2px}.folder-head:hover{color:var(--fg-secondary)}.folder-head.drop-target{background:var(--accent-soft);color:var(--accent)}.folder-head .caret{transition:transform var(--dur-fast) var(--ease-out);font-size:9px;color:var(--fg-tertiary);width:10px;text-align:center}.folder-head.expanded .caret{transform:rotate(90deg)}.folder-head .name{color:var(--fg-secondary);font-weight:var(--fw-semi);font-family:var(--font-sans);font-size:var(--fs-sm);text-transform:none;letter-spacing:.02em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.folder-head.drop-target .name{color:var(--accent)}.folder-head .num{margin-left:auto;color:var(--fg-tertiary);font-variant-numeric:tabular-nums}.folder-head .drag-dots{color:var(--fg-disabled);font-size:10px;cursor:grab}.folder-head .drag-dots:active{cursor:grabbing}.folder-head .folder-actions{display:inline-flex;gap:2px;opacity:0;transition:opacity var(--dur-fast) var(--ease-out)}.folder-head:hover .folder-actions{opacity:1}.folder-head .folder-actions button{width:20px;height:20px;border-radius:var(--r-sm);color:var(--fg-tertiary);font-size:11px;display:inline-flex;align-items:center;justify-content:center}.folder-head .folder-actions button:hover{background:var(--bg-raised);color:var(--fg-primary)}.folder-head .folder-actions button.del:hover{color:var(--red)}.folder-rename-input{flex:1;font-family:var(--font-sans);font-size:var(--fs-sm);padding:2px 6px;background:var(--bg-raised);border:1px solid var(--accent);border-radius:var(--r-sm);color:var(--fg-primary);outline:none}.todo-list{display:flex;flex-direction:column;gap:4px;padding-left:8px}.todo-row{position:relative;display:flex;align-items:center;gap:10px;padding:8px 12px 8px 14px;background:var(--bg-surface);border:1px solid var(--border-soft);border-left:3px solid var(--border-soft);border-radius:var(--r-md);transition:all var(--dur-fast) var(--ease-out)}.todo-row:hover{border-color:var(--border-hard);background:var(--bg-raised)}.todo-row.pri-high{border-left-color:var(--red)}.todo-row.pri-medium{border-left-color:var(--amber)}.todo-row.pri-low{border-left-color:var(--fg-tertiary)}.todo-row.done{opacity:.55}.todo-row.done .todo-text{text-decoration:line-through;color:var(--fg-tertiary)}.todo-row.editing{flex-direction:column;align-items:stretch;gap:8px;padding:10px 12px}.drag-handle{color:var(--fg-disabled);font-size:11px;cursor:grab;flex-shrink:0;letter-spacing:-1px;font-family:var(--font-mono);-webkit-user-select:none;-moz-user-select:none;user-select:none}.drag-handle:hover{color:var(--fg-tertiary)}.drag-handle:active{cursor:grabbing}.check{flex-shrink:0;width:16px;height:16px;border:1.5px solid var(--border-hard);border-radius:3px;display:inline-flex;align-items:center;justify-content:center;transition:all var(--dur-fast) var(--ease-out);background:var(--bg-app);color:transparent;font-size:11px;font-weight:var(--fw-bold)}.check:hover{border-color:var(--accent)}.check.checked{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}.pri-pill{font-family:var(--font-mono);font-size:10px;padding:2px 6px;border-radius:3px;flex-shrink:0;letter-spacing:.04em;font-weight:var(--fw-medium)}.pri-pill.high{background:var(--red-soft);color:var(--red)}.pri-pill.medium{background:var(--amber-soft);color:var(--amber)}.pri-pill.low{background:var(--bg-raised);color:var(--fg-tertiary);border:1px solid var(--border-soft)}.todo-text{flex:1;font-size:var(--fs-md);color:var(--fg-primary);line-height:var(--lh-snug);word-break:break-word;min-width:0}.todo-actions{display:inline-flex;gap:2px;opacity:0;transition:opacity var(--dur-fast) var(--ease-out);flex-shrink:0}.todo-row:hover .todo-actions{opacity:1}.todo-actions button{width:22px;height:22px;border-radius:var(--r-sm);color:var(--fg-tertiary);font-size:12px;display:inline-flex;align-items:center;justify-content:center;transition:all var(--dur-fast) var(--ease-out)}.todo-actions button:hover{background:var(--bg-app);color:var(--fg-primary)}.todo-actions button.del:hover{color:var(--red)}.todo-edit-input{width:100%;background:transparent;border:none;border-bottom:1px solid var(--border-hard);padding:4px 2px;color:var(--fg-primary);font-size:var(--fs-md);outline:none}.todo-edit-input:focus{border-color:var(--accent)}.todo-edit-controls{display:flex;gap:8px;align-items:center}.drag-preview{background:var(--bg-raised);border:1px solid var(--accent);border-left:3px solid var(--accent);border-radius:var(--r-md);padding:8px 12px;display:flex;align-items:center;gap:10px;box-shadow:0 12px 32px -8px #0009,0 0 0 1px var(--accent-soft);color:var(--fg-primary);font-size:var(--fs-md)}.drag-preview.folder{font-family:var(--font-mono);font-size:var(--fs-sm);text-transform:none;letter-spacing:.02em;color:var(--fg-secondary)}.drop-line{display:flex;align-items:center;gap:4px;padding:1px 4px;height:8px}.drop-line:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0}.drop-line:after{content:"";flex:1;height:2px;background:var(--accent);border-radius:1px}.memo-list{display:flex;flex-direction:column;gap:8px}.memo-card{background:var(--bg-surface);border:1px solid var(--border-soft);border-radius:var(--r-md);padding:12px 16px;display:flex;align-items:center;gap:10px;transition:border-color var(--dur-fast) var(--ease-out)}.memo-card:hover{border-color:var(--border-hard)}.memo-card .memo-open{flex:1;min-width:0;text-align:left;display:flex;flex-direction:column;gap:4px}.memo-title{font-size:var(--fs-md);font-weight:var(--fw-medium);color:var(--fg-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.memo-meta{font-family:var(--font-mono);font-size:10px;color:var(--fg-tertiary);letter-spacing:.04em}.memo-editor-card{background:var(--bg-surface);border:1px solid var(--border-soft);border-radius:var(--r-md);padding:12px;display:flex;flex-direction:column;gap:10px}.memo-editor-card textarea{width:100%;min-height:180px;background:transparent;border:none;outline:none;resize:vertical;color:var(--fg-primary);font-size:var(--fs-md);line-height:var(--lh-normal)}.memo-editor-card textarea::-moz-placeholder{color:var(--fg-tertiary)}.memo-editor-card textarea::placeholder{color:var(--fg-tertiary)}.new-memo-btn{width:100%;background:transparent;border:1px dashed var(--border-hard);color:var(--fg-tertiary);padding:14px;border-radius:var(--r-md);font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;transition:all var(--dur-fast) var(--ease-out);margin-bottom:12px}.new-memo-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.history-toolbar{display:flex;gap:8px;align-items:center;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--border-soft)}.history-toolbar .note{flex:1;font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-tertiary)}.log-list{display:flex;flex-direction:column}.log-row{display:flex;align-items:center;gap:12px;padding:8px 12px;border-bottom:1px solid var(--border-soft);font-family:var(--font-mono);font-size:11px}.log-row:hover{background:var(--bg-surface)}.log-time{color:var(--fg-tertiary);flex-shrink:0;font-variant-numeric:tabular-nums;width:92px}.log-action{font-weight:var(--fw-semi);flex-shrink:0;padding:2px 6px;border-radius:2px;width:100px;text-align:center;letter-spacing:.04em;font-size:10px}.log-action.a-add{color:var(--accent);background:var(--accent-soft)}.log-action.a-edit{color:var(--violet);background:var(--violet-soft)}.log-action.a-complete{color:var(--green);background:var(--green-soft)}.log-action.a-uncomplete{color:var(--amber);background:var(--amber-soft)}.log-action.a-delete{color:var(--red);background:var(--red-soft)}.log-action.a-move{color:var(--indigo);background:var(--indigo-soft)}.log-action.a-folder,.log-action.a-restore{color:var(--teal);background:var(--teal-soft)}.log-target{flex:1;color:var(--fg-secondary);font-family:var(--font-sans);font-size:var(--fs-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.log-restore{font-family:var(--font-mono);font-size:10px;padding:3px 8px;border-radius:var(--r-sm);color:var(--teal);border:1px solid var(--teal);opacity:.75;transition:all var(--dur-fast) var(--ease-out);letter-spacing:.04em}.log-restore:hover{opacity:1;background:var(--teal-soft)}.empty{padding:60px 20px;text-align:center;color:var(--fg-tertiary);font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase}.empty .art{width:48px;height:48px;margin:0 auto 16px;border:1px dashed var(--border-hard);border-radius:var(--r-sm);display:inline-flex;align-items:center;justify-content:center;color:var(--fg-disabled);font-size:20px}.empty .sub{margin-top:8px;font-size:10px;letter-spacing:.1em;color:var(--fg-disabled)}.loading-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-app);color:var(--fg-tertiary);font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase}.divider-label{display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg-tertiary);margin:18px 0 8px}.divider-label:before,.divider-label:after{content:"";flex:1;height:1px;background:var(--border-soft)}*::-webkit-scrollbar{width:8px;height:8px}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{background:var(--border-hard);border-radius:4px}*::-webkit-scrollbar-thumb:hover{background:var(--fg-tertiary)}.auth-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--bg-app);position:relative;background-image:linear-gradient(var(--grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--grid-line) 1px,transparent 1px),linear-gradient(var(--grid-major) 1px,transparent 1px),linear-gradient(90deg,var(--grid-major) 1px,transparent 1px);background-size:16px 16px,16px 16px,80px 80px,80px 80px}.auth-top-actions{position:absolute;top:16px;right:16px;display:flex;gap:4px}.auth-card{width:100%;max-width:380px;background:var(--bg-surface);border:1px solid var(--border-soft);border-radius:var(--r-lg);padding:32px 28px;display:flex;flex-direction:column;gap:20px}.auth-brand{display:flex;align-items:center;gap:10px}.auth-brand .logo-mark{width:36px;height:36px;font-size:16px;border-radius:var(--r-sm)}.auth-brand .title{font-family:var(--font-mono);font-size:18px;font-weight:var(--fw-bold);letter-spacing:.08em;color:var(--fg-primary)}.auth-sub{font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-tertiary);margin-top:-12px}.form-field{display:flex;flex-direction:column;gap:6px}.form-field label{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-tertiary)}.text-input{background:var(--bg-raised);border:1px solid var(--border-soft);border-radius:var(--r-sm);padding:8px 10px;font-size:var(--fs-md);color:var(--fg-primary);outline:none;transition:all var(--dur-fast) var(--ease-out);width:100%}.text-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.btn-block{width:100%;padding:10px 14px}.alert{font-size:var(--fs-sm);padding:8px 10px;border-radius:var(--r-sm);border:1px solid;line-height:var(--lh-snug)}.alert.error{color:var(--red);background:var(--red-soft);border-color:var(--red)}.alert.success{color:var(--green);background:var(--green-soft);border-color:var(--green)}.auth-switch{font-size:var(--fs-sm);color:var(--fg-tertiary);text-align:center}.auth-switch button{color:var(--accent);font-weight:var(--fw-medium)}.auth-switch button:hover{color:var(--accent-hover)}.m-root{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;background:var(--bg-app);overflow-x:hidden;max-width:100vw}.m-header{padding:10px 16px;border-bottom:1px solid var(--border-soft);background:var(--bg-surface);flex-shrink:0}.m-header-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.m-header-title{font-family:var(--font-mono);font-size:12px;font-weight:var(--fw-bold);letter-spacing:.08em;display:flex;align-items:center;gap:8px}.m-header-actions{display:flex;gap:2px}.m-header-actions .icon-btn{width:32px;height:32px}.m-body{flex:1;overflow-y:auto;padding:12px 16px 92px}.m-toolbar{display:flex;align-items:center;gap:10px;margin-bottom:10px;font-size:var(--fs-sm)}.m-card{background:var(--bg-surface);border:1px solid var(--border-soft);border-left:3px solid var(--border-soft);border-radius:var(--r-md);padding:10px 12px;display:flex;align-items:center;gap:10px;margin-bottom:6px}.m-card.pri-high{border-left-color:var(--red)}.m-card.pri-medium{border-left-color:var(--amber)}.m-card.pri-low{border-left-color:var(--fg-tertiary)}.m-card.done{opacity:.55}.m-card.done .m-text{text-decoration:line-through;color:var(--fg-tertiary)}.m-check{width:22px;height:22px;border:1.5px solid var(--border-hard);border-radius:4px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;color:transparent;font-size:13px;font-weight:var(--fw-bold);transition:all var(--dur-fast) var(--ease-out);background:var(--bg-app)}.m-check.checked{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}.m-text{flex:1;font-size:var(--fs-md);line-height:var(--lh-snug);color:var(--fg-primary);min-width:0;word-break:break-word}.m-folder-hdr{display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-tertiary);padding:14px 4px 6px;border-bottom:1px dashed var(--border-soft);margin-bottom:6px;width:100%;text-align:left}.m-folder-hdr .name{font-family:var(--font-sans);font-size:var(--fs-sm);letter-spacing:.02em;text-transform:none;color:var(--fg-secondary);font-weight:var(--fw-semi)}.m-folder-hdr .num{margin-left:auto;font-variant-numeric:tabular-nums;color:var(--fg-disabled)}.fab{position:fixed;right:20px;bottom:calc(96px + env(safe-area-inset-bottom,0));width:52px;height:52px;background:var(--accent);color:var(--accent-ink);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;box-shadow:0 8px 24px -4px rgba(var(--accent-rgb),.45),0 0 0 1px rgba(var(--accent-rgb),.55);z-index:4;line-height:1}.fab:hover{background:var(--accent-hover)}.m-nav{flex-shrink:0;height:74px;background:var(--bg-surface);border-top:1px solid var(--border-hard);display:flex;padding:6px 6px calc(10px + env(safe-area-inset-bottom,0));z-index:3;gap:4px}.m-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;font-family:var(--font-sans);font-size:12px;font-weight:var(--fw-semi);letter-spacing:.02em;color:var(--fg-secondary);padding:4px;border-radius:var(--r-md);transition:all var(--dur-fast) var(--ease-out);position:relative}.m-nav-item:active{background:var(--bg-raised)}.m-nav-item .icon{font-size:20px;line-height:1;width:40px;height:24px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--r-pill);transition:all var(--dur-fast) var(--ease-out)}.m-nav-item.active{color:var(--accent)}.m-nav-item.active .icon{background:var(--accent-soft);color:var(--accent)}.m-nav-item .label-row{display:inline-flex;align-items:center;gap:4px}.m-nav-item .badge{font-family:var(--font-mono);font-size:10px;font-weight:var(--fw-semi);color:inherit;font-variant-numeric:tabular-nums;padding:1px 5px;border-radius:var(--r-pill);background:var(--bg-raised);line-height:1.4}.m-nav-item.active .badge{background:var(--accent-soft);color:var(--accent)}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:var(--z-overlay)}.sheet{position:fixed;left:0;right:0;bottom:0;z-index:calc(var(--z-overlay) + 1);background:var(--bg-surface);border-top:1px solid var(--border-soft);border-radius:var(--r-xl) var(--r-xl) 0 0;padding:10px 20px calc(16px + env(safe-area-inset-bottom,0));box-shadow:0 -16px 40px -8px #00000080;max-height:85vh;overflow-y:auto}.sheet-grabber{width:36px;height:4px;background:var(--border-hard);border-radius:2px;margin:4px auto 14px}.sheet-title{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-secondary);margin-bottom:12px}.sheet-field{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.sheet-field label{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-tertiary)}.sheet-textarea{width:100%;background:var(--bg-raised);border:1px solid var(--border-soft);border-radius:var(--r-sm);padding:10px 12px;font-size:var(--fs-md);color:var(--fg-primary);outline:none;resize:vertical;min-height:80px;transition:all var(--dur-fast) var(--ease-out)}.sheet-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.pri-row{display:flex;gap:6px}.pri-row button{flex:1;padding:10px;font-family:var(--font-mono);font-size:var(--fs-sm);font-weight:var(--fw-medium);letter-spacing:.04em;border:1px solid var(--border-soft);border-radius:var(--r-sm);color:var(--fg-tertiary);background:var(--bg-raised);transition:all var(--dur-fast) var(--ease-out)}.pri-row button.sel-high{background:var(--red-soft);color:var(--red);border-color:var(--red)}.pri-row button.sel-medium{background:var(--amber-soft);color:var(--amber);border-color:var(--amber)}.pri-row button.sel-low{background:var(--bg-app);color:var(--fg-secondary);border-color:var(--border-hard)}.sheet-actions{display:flex;gap:10px;margin-top:16px}.sheet-actions>*{flex:1}.memo-fullscreen{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-app);display:flex;flex-direction:column;z-index:var(--z-modal)}.memo-fullscreen-head{height:52px;padding:0 16px;background:var(--bg-surface);border-bottom:1px solid var(--border-soft);display:flex;align-items:center;gap:12px;flex-shrink:0}.memo-fullscreen-head .back{color:var(--accent);font-family:var(--font-mono);font-size:11px;letter-spacing:.06em}.memo-fullscreen-head .title{flex:1;font-size:var(--fs-md);font-weight:var(--fw-medium);color:var(--fg-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.memo-fullscreen textarea{flex:1;background:transparent;border:none;outline:none;padding:16px 20px;color:var(--fg-primary);font-size:var(--fs-md);line-height:var(--lh-normal);resize:none}.memo-fullscreen textarea::-moz-placeholder{color:var(--fg-tertiary)}.memo-fullscreen textarea::placeholder{color:var(--fg-tertiary)}.folder-row{display:flex;align-items:center;gap:8px;padding:10px 4px;border-bottom:1px solid var(--border-soft)}.folder-row:last-child{border-bottom:none}.folder-row .name{flex:1;font-size:var(--fs-md);color:var(--fg-primary)}.folder-row .count{font-family:var(--font-mono);font-size:10px;color:var(--fg-tertiary)}.folder-row .icon-btn{width:32px;height:32px}.inline-add-folder{display:flex;gap:6px;flex:1;align-items:center}.inline-add-folder input{flex:1;background:var(--bg-raised);border:1px solid var(--border-soft);border-radius:var(--r-sm);padding:5px 8px;font-size:var(--fs-sm);color:var(--fg-primary);outline:none}.inline-add-folder input:focus{border-color:var(--accent)}.copied-hint{color:var(--green)}.activity-sidebar{width:320px;flex-shrink:0;border-left:1px solid var(--border-soft);background:var(--bg-sunken);display:flex;flex-direction:column;overflow:hidden}@media(max-width:1023px){.activity-sidebar{width:280px}}@media(max-width:879px){.activity-sidebar{display:none}}.activity-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px;border-bottom:1px solid var(--border-soft);flex-shrink:0}.activity-title{font-family:var(--font-mono);font-size:10px;font-weight:var(--fw-semi);letter-spacing:.16em;text-transform:uppercase;color:var(--fg-secondary)}.activity-count{font-family:var(--font-mono);font-size:10px;color:var(--fg-tertiary);font-variant-numeric:tabular-nums;padding:2px 6px;border:1px solid var(--border-soft);border-radius:3px}.activity-toolbar{display:flex;gap:6px;padding:10px 12px;border-bottom:1px solid var(--border-soft);flex-shrink:0}.activity-toolbar .btn-ghost{flex:1;font-size:10px;padding:5px 6px}.activity-log{flex:1;overflow-y:auto;padding:4px 0}.activity-row{display:flex;flex-direction:column;gap:4px;padding:8px 14px;border-bottom:1px solid var(--border-soft);transition:background-color var(--dur-fast) var(--ease-out)}.activity-row:hover{background:var(--bg-surface)}.activity-row:last-child{border-bottom:none}.activity-row-head{display:flex;align-items:center;gap:8px}.activity-row-head .log-action{width:auto;min-width:80px;flex-shrink:0}.activity-time{font-family:var(--font-mono);font-size:10px;color:var(--fg-tertiary);font-variant-numeric:tabular-nums;margin-left:auto;flex-shrink:0}.activity-target{font-size:12px;color:var(--fg-secondary);line-height:var(--lh-snug);word-break:break-word;padding-left:2px}@media(max-width:768px){input[type=text],input[type=email],input[type=password],input[type=search],input[type=number],input[type=url],input:not([type]),select,textarea,.text-input,.sheet-textarea,.composer input[type=text],.composer textarea,.folder-picker,.folder-rename-input,.tpl-editor-row input,.todo-edit-input{font-size:16px!important}}.templates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;margin-top:4px}.tpl-card{background:var(--bg-surface);border:1px solid var(--border-soft);border-radius:var(--r-md);padding:14px;display:flex;flex-direction:column;gap:8px;cursor:pointer;transition:all var(--dur-fast) var(--ease-out);position:relative;text-align:left}.tpl-card:hover{border-color:var(--accent);background:var(--bg-raised)}.tpl-card:hover .tpl-apply{opacity:1}.tpl-head{display:flex;align-items:center;gap:10px}.tpl-icon{width:32px;height:32px;border:1px solid var(--border-hard);border-radius:var(--r-sm);display:inline-flex;align-items:center;justify-content:center;color:var(--accent);background:var(--accent-soft);font-size:16px;flex-shrink:0}.tpl-name{font-size:var(--fs-md);font-weight:var(--fw-semi);color:var(--fg-primary);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tpl-count{font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;color:var(--fg-tertiary);padding:2px 6px;border:1px solid var(--border-soft);border-radius:3px;flex-shrink:0;font-variant-numeric:tabular-nums}.tpl-items{display:flex;flex-direction:column;gap:3px;margin-top:2px;padding-top:10px;border-top:1px dashed var(--border-soft)}.tpl-item{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--fg-secondary)}.tpl-item .bullet{width:2px;height:10px;background:var(--border-hard);flex-shrink:0}.tpl-item.pri-high .bullet{background:var(--red)}.tpl-item.pri-medium .bullet{background:var(--amber)}.tpl-item.pri-low .bullet{background:var(--fg-tertiary)}.tpl-item .t{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tpl-item.more{color:var(--fg-disabled);font-family:var(--font-mono);font-size:10px;margin-top:2px;letter-spacing:.06em}.tpl-apply{position:absolute;top:10px;right:10px;background:var(--accent);color:var(--accent-ink);font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;padding:4px 10px;border-radius:var(--r-sm);opacity:0;transition:opacity var(--dur-fast) var(--ease-out);font-weight:var(--fw-semi)}.tpl-apply:hover{background:var(--accent-hover)}.tpl-actions{display:inline-flex;gap:2px;margin-left:auto}.tpl-actions button{width:22px;height:22px;border-radius:var(--r-sm);color:var(--fg-tertiary);font-size:12px;display:inline-flex;align-items:center;justify-content:center;transition:all var(--dur-fast) var(--ease-out)}.tpl-actions button:hover{background:var(--bg-app);color:var(--fg-primary)}.tpl-actions button.del:hover{color:var(--red)}.tpl-new{background:transparent;border:1px dashed var(--border-hard);color:var(--fg-tertiary);display:flex;align-items:center;justify-content:center;min-height:140px;gap:6px;font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;border-radius:var(--r-md);cursor:pointer;transition:all var(--dur-fast) var(--ease-out)}.tpl-new:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:var(--z-overlay);display:flex;align-items:center;justify-content:center;padding:24px}.modal-card{background:var(--bg-surface);border:1px solid var(--border-hard);border-radius:var(--r-lg);width:100%;max-width:560px;max-height:calc(100vh - 48px);display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px -10px #0009}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border-soft);flex-shrink:0}.modal-head .title{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-secondary)}.modal-body{padding:16px 18px;overflow-y:auto;display:flex;flex-direction:column;gap:14px}.modal-foot{display:flex;justify-content:flex-end;gap:8px;padding:12px 18px;border-top:1px solid var(--border-soft);flex-shrink:0}.tpl-editor-items{display:flex;flex-direction:column;gap:6px}.tpl-editor-row{display:flex;align-items:center;gap:8px;background:var(--bg-raised);border:1px solid var(--border-soft);border-left:3px solid var(--border-soft);border-radius:var(--r-sm);padding:6px 8px}.tpl-editor-row.pri-high{border-left-color:var(--red)}.tpl-editor-row.pri-medium{border-left-color:var(--amber)}.tpl-editor-row.pri-low{border-left-color:var(--fg-tertiary)}.tpl-editor-row input{flex:1;background:transparent;border:none;outline:none;font-size:var(--fs-md);color:var(--fg-primary);min-width:0}.tpl-editor-row .num{font-family:var(--font-mono);font-size:10px;color:var(--fg-tertiary);width:18px;flex-shrink:0;font-variant-numeric:tabular-nums}.tpl-editor-add{font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;color:var(--fg-tertiary);border:1px dashed var(--border-hard);border-radius:var(--r-sm);padding:8px;text-align:center;transition:all var(--dur-fast) var(--ease-out);cursor:pointer;text-transform:uppercase}.tpl-editor-add:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-soft)}
