:root{--bg: #f6f8fb;--panel: #ffffff;--panel-2: #fbfcff;--text: #0f172a;--muted: #64748b;--border: rgba(15, 23, 42, .1);--shadow: 0 10px 30px rgba(15, 23, 42, .08);--shadow-soft: 0 6px 16px rgba(15, 23, 42, .06);--primary: #2563eb;--primary-hover: #1d4ed8;--primary-weak: rgba(37, 99, 235, .1);--ok: #16a34a;--warn: #f59e0b;--danger: #dc2626;--radius: 14px;--radius-sm: 10px;--gap: 14px;--font: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji";--mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace}*{box-sizing:border-box}html,body,#root{height:100%;margin:0;font-family:var(--font);color:var(--text);background:var(--bg)}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}.journal{height:100vh;display:flex;flex-direction:column;padding:18px;gap:var(--gap)}@media(max-width:720px){.journal{padding:12px;gap:10px}}.journal-header{display:flex;align-items:center;gap:12px;padding:14px 16px;background:linear-gradient(180deg,var(--panel) 0%,var(--panel-2) 100%);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-soft)}.journal-title{display:flex;flex-direction:column;min-width:180px}.journal-title .label{font-size:12px;color:var(--muted);letter-spacing:.02em}.journal-title .value{font-size:18px;font-weight:700;line-height:1.2}.journal-status{margin-left:auto;font-size:12px;color:var(--muted);padding:6px 10px;border:1px solid var(--border);border-radius:999px;background:#fff;box-shadow:0 1px #0f172a08;white-space:nowrap}@media(max-width:720px){.journal-header{flex-wrap:wrap}.journal-status{margin-left:0;order:3;width:100%;text-align:center}}button{font-family:var(--font);border:1px solid var(--border);background:#fff;padding:10px 12px;border-radius:12px;cursor:pointer;font-weight:600;color:var(--text);transition:transform .12s ease,box-shadow .12s ease,background .12s ease,border-color .12s ease}button:hover{box-shadow:0 10px 24px #0f172a1a;transform:translateY(-1px)}button:active{transform:translateY(0);box-shadow:none}button:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}button.primary{background:linear-gradient(180deg,var(--primary) 0%,var(--primary-hover) 100%);color:#fff;border-color:#2563eb59}button.primary:hover{background:linear-gradient(180deg,var(--primary-hover) 0%,var(--primary-hover) 100%)}button.ghost{background:transparent}.banner{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);background:#fff;box-shadow:var(--shadow-soft)}.banner strong{font-weight:700}.banner button{padding:8px 10px;border-radius:10px}.banner.warn{border-color:#f59e0b47;background:#f59e0b1a}.banner.warn button{background:#fff}.journal-main{flex:1;min-height:0;display:flex;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.journal-editor{flex:1;width:100%;border:none;outline:none;resize:none;padding:18px 18px 22px;font-size:16px;line-height:1.55;color:var(--text);background:transparent;caret-color:var(--primary)}.journal-editor::placeholder{color:#64748bbf}.journal-main:focus-within{border-color:#2563eb59;box-shadow:0 0 0 4px #2563eb1f,var(--shadow)}.journal-editor::-webkit-scrollbar{width:10px}.journal-editor::-webkit-scrollbar-thumb{background:#0f172a2e;border-radius:10px}.journal-editor::-webkit-scrollbar-thumb:hover{background:#0f172a47}.login{min-height:100vh;display:grid;place-items:center;padding:16px}.login-card{width:100%;max-width:420px;background:#fff;border:1px solid rgba(15,23,42,.1);border-radius:14px;padding:18px;box-shadow:0 10px 30px #0f172a14}.login-card h1{margin:0 0 6px;font-size:20px}.muted{color:#64748b;margin:0 0 14px}.login-form{display:grid;gap:12px}.login-form label{display:grid;gap:6px;font-size:13px;font-weight:600}.login-form input{font:inherit;padding:10px 12px;border-radius:12px;border:1px solid rgba(15,23,42,.14);outline:none}.login-form input:focus{border-color:#2563eb73;box-shadow:0 0 0 4px #2563eb1f}.hint{font-size:12px;color:#64748b}.error{font-size:13px;color:#dc2626;font-weight:600}.modal-sub{font-size:12px;color:#64748b;margin-top:2px}.modal-search{margin:12px 16px 10px;padding:10px 12px;border-radius:12px;border:1px solid rgba(15,23,42,.14);outline:none}.modal-search:focus{border-color:#2563eb73;box-shadow:0 0 0 4px #2563eb1f}.modal-body{padding:0 16px 16px;overflow:auto}.results{display:grid;gap:8px}.result-row{text-align:left;display:grid;gap:2px;padding:10px 12px;border-radius:12px;border:1px solid rgba(15,23,42,.12);background:#fff}.result-row.active{border-color:#2563eb59;background:#2563eb14}.result-name{font-weight:700}.result-hint{font-size:12px;color:#64748b}.empty{display:grid;gap:10px;padding:10px 0 0}.error{color:#dc2626;font-weight:700}.muted{color:#64748b}.journal-preview{flex:1;min-height:0;display:flex;background:#fff;border:1px solid rgba(15,23,42,.1);border-radius:14px;box-shadow:0 10px 30px #0f172a14;overflow:hidden}.journal-preview-body{width:100%;padding:18px 18px 22px;font-size:16px;line-height:1.55;color:#0f172a;overflow:auto;white-space:normal}.chip{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;margin:0 2px;border-radius:999px;border:1px solid rgba(15,23,42,.14);background:#0f172a0a;font-weight:700;font-size:.95em;cursor:pointer;vertical-align:baseline;box-shadow:none;transform:none}.chip:hover{box-shadow:0 8px 18px #0f172a1a;transform:translateY(-1px)}.chip-person{border-color:#2563eb40;background:#2563eb1a}.chip-place{border-color:#10a34a40;background:#10a34a1a}button.small{padding:8px 10px;border-radius:10px;font-weight:700;font-size:13px}.modal-backdrop{position:fixed;inset:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:16px;z-index:50}.modal{width:min(720px,100%);max-height:85vh;background:#fff;border-radius:14px;border:1px solid rgba(15,23,42,.12);box-shadow:0 18px 50px #0f172a38;padding:14px;display:flex;flex-direction:column;gap:12px}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.modal-title{font-weight:800}.notes-editor{width:100%;min-height:320px;resize:vertical;padding:12px;border-radius:12px;border:1px solid rgba(15,23,42,.16);font-size:15px;line-height:1.45}.archive{display:flex;flex-direction:column;gap:12px;height:100%;min-height:0}.archive-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.archive-title .label{font-size:12px;opacity:.7;font-weight:700}.archive-title .value{font-size:18px;font-weight:900}.archive-body{display:grid;grid-template-columns:360px 1fr;gap:12px;min-height:0;flex:1}.archive-list{background:#fff;border:1px solid rgba(15,23,42,.1);border-radius:14px;box-shadow:0 10px 30px #0f172a14;padding:8px;overflow:auto;min-height:0}.archive-row{width:100%;text-align:left;border:1px solid transparent;border-radius:12px;padding:10px;background:transparent;cursor:pointer}.archive-row:hover{background:#0f172a08}.archive-row.active{border-color:#2563eb40;background:#2563eb14}.archive-row-top{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.archive-date{font-weight:900}.archive-meta{font-size:12px;opacity:.7;font-weight:700;white-space:nowrap}.archive-excerpt{margin-top:4px;font-size:13px;opacity:.85}.archive-view{min-height:0;display:flex}.archive-view>*{width:100%}@media(max-width:900px){.archive-body{grid-template-columns:1fr}}.board{display:flex;flex-direction:column;gap:12px;height:100%;min-height:0}.board-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.board-title .label{font-size:12px;opacity:.7;font-weight:800}.board-title .value{font-size:18px;font-weight:900}.board-actions{display:flex;gap:8px;flex-wrap:wrap}.board-status{font-size:12px;opacity:.75;font-weight:800;white-space:nowrap}.board-canvas{touch-action:none}.board-node{position:absolute;width:160px;padding:10px;border-radius:14px;border:1px solid rgba(15,23,42,.12);background:#0f172a08;box-shadow:0 10px 26px #0f172a1a;cursor:grab;-webkit-user-select:none;user-select:none}.board-node:active{cursor:grabbing}.board-node-title{font-weight:900;font-size:14px;color:#0f172a}.board-node-sub{margin-top:4px;font-size:11px;opacity:.65;word-break:break-all}.board-world{position:absolute;left:0;top:0;width:100%;height:100%;transform-origin:0 0}.board-edges{position:absolute;inset:0;width:100%;height:100%;overflow:visible}.board-node.selected{border-color:#2563eb59;background:#2563eb1a}button.tiny{margin-top:8px;padding:6px 8px;border-radius:10px;font-weight:800;font-size:12px;border:1px solid rgba(15,23,42,.14);background:#0f172a0a;cursor:pointer}button.tiny:hover{background:#0f172a12}.form-label{font-size:12px;font-weight:800;opacity:.75}.input{width:100%;padding:10px 12px;border-radius:12px;border:1px solid rgba(15,23,42,.16);font-size:14px}.modal-footer{display:flex;justify-content:space-between;gap:10px}button.warn{border-color:#dc262640;background:#dc26261a}@media(max-width:720px){.modal-backdrop{align-items:stretch;justify-content:stretch;padding:0}.modal{width:100vw;height:100vh;max-width:none;max-height:none;border-radius:0;display:flex;flex-direction:column}.modal-header{position:sticky;top:0;z-index:5;background:#fff;padding-top:env(safe-area-inset-top)}.modal-body{flex:1;overflow:auto;-webkit-overflow-scrolling:touch;padding-bottom:72px}.modal-footer{position:sticky;bottom:0;z-index:5;background:#fff;padding-bottom:env(safe-area-inset-bottom)}.modal-footer .primary,.modal-footer .small,.modal-footer button{width:100%;height:44px}.picker-search-row{position:sticky;top:0;z-index:3;background:#fff;padding:12px 0 10px}.picker-search-row{display:flex;gap:8px;align-items:center}.picker-clear{width:44px;height:44px;border-radius:12px;border:1px solid rgba(15,23,42,.14);background:#0f172a08;font-size:22px;line-height:1;padding:0}.modal-sub{display:none}.result-row{padding:12px}}
