:root{--bg:#fbf1f2;--bg-soft:#fdf6f6;--card:#fff;--ink:#4f3d40;--muted:#9a8488;--faint:#c2afb2;--line:#efdcde;--line-soft:#f6e9eb;--accent:#b27f86;--accent-strong:#9c6a72;--accent-soft:#fceef0;--deep:#6e565a;--danger:#c25d6e;--danger-soft:#fceef0;--radius:18px;--mono:ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;--sans:system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--script:"Great Vibes", cursive}*{box-sizing:border-box}html,body,#root{height:100%}body{background:var(--bg);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;margin:0}.app{min-height:100%}.container{max-width:680px;margin:0 auto;padding:32px 16px 96px}.header{margin-bottom:28px}.brand{align-items:center;gap:12px;display:flex}.brand-badge{background:var(--accent);color:#fff;border-radius:999px;flex:none;justify-content:center;align-items:center;width:40px;height:40px;display:flex;box-shadow:0 3px 10px #b27f8661}.brand-title{font-family:var(--script);letter-spacing:.5px;color:var(--accent);margin:0;font-size:34px;font-weight:400;line-height:1}.brand-sub{font-family:var(--mono);color:var(--muted);letter-spacing:.12em;margin:4px 0 0;font-size:11px}.tabs{background:var(--card);border:1px solid var(--line);border-radius:14px;gap:2px;margin-top:24px;padding:4px;display:inline-flex}.tab{color:var(--muted);font-family:var(--sans);cursor:pointer;background:0 0;border:0;border-radius:10px;align-items:center;gap:6px;padding:7px 16px;font-size:14px;font-weight:500;transition:background .15s,color .15s;display:inline-flex}.tab:hover{color:var(--ink)}.tab.active{background:var(--accent);color:#fff}.notice{background:var(--accent-soft);color:var(--accent-strong);border:1px solid #f0cdd2;border-radius:12px;margin-bottom:20px;padding:12px 16px;font-size:14px;line-height:1.5}.field-label{color:var(--ink);margin-bottom:6px;font-size:14px;font-weight:500;display:block}.field-label .opt{color:var(--faint);font-weight:400}.input,.textarea{width:100%;font-family:var(--sans);color:var(--ink);background:var(--card);border:1px solid var(--line);border-radius:12px;outline:none;padding:12px 14px;font-size:14px;transition:border-color .15s,box-shadow .15s}.textarea{resize:vertical;border-radius:10px;min-height:56px}.input:focus,.textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #b27f8629}.input.error,.textarea.error{border-color:#e6a3ac}.input.error:focus{box-shadow:0 0 0 3px #c25d6e29}.spacer-md{margin-bottom:20px}.dropzone{background:var(--card);border-radius:var(--radius);text-align:center;cursor:pointer;width:100%;color:var(--muted);border:2px dashed #e2c4c8;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:56px 24px;transition:border-color .15s,background .15s;display:flex}.dropzone:hover{border-color:var(--accent);background:var(--accent-soft)}.dropzone:disabled{opacity:.6;cursor:default}.dropzone .dz-title{color:var(--ink);font-size:14px;font-weight:500}.dropzone .dz-hint{color:var(--faint);font-size:12px}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}.stack>*+*{margin-top:12px}.img-wrap{background:#faf2f3;position:relative}.img-wrap img{object-fit:contain;width:100%;max-height:300px;display:block}.exhibit{font-family:var(--mono);letter-spacing:.06em;color:#fff;background:var(--deep);border-radius:6px;align-items:center;padding:3px 8px;font-size:11px;font-weight:600;display:inline-flex}.exhibit.accent{background:var(--accent)}.img-tag{position:absolute;top:12px;left:12px}.icon-x{color:#fff;cursor:pointer;background:#4f3d408c;border:0;border-radius:999px;justify-content:center;align-items:center;width:32px;height:32px;display:flex;position:absolute;top:12px;right:12px}.icon-x:hover{background:#4f3d40c7}.card-pad{padding:12px}.btn{font-family:var(--sans);cursor:pointer;border:1px solid #0000;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:12px 18px;font-size:14px;font-weight:600;transition:background .15s,border-color .15s,color .15s,opacity .15s;display:inline-flex}.btn:disabled{opacity:.55;cursor:default}.btn-block{width:100%}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-strong)}.btn-dark{background:var(--deep);color:#fff}.btn-dark:hover:not(:disabled){background:#5b464a}.btn-dashed{background:var(--card);width:100%;color:var(--muted);border:1px dashed #e2c4c8;font-weight:500}.btn-dashed:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.success{background:var(--card);border-radius:var(--radius);text-align:center;border:1px solid #f0cdd2;padding:36px 24px}.success-icon{background:var(--accent-soft);width:48px;height:48px;color:var(--accent);border-radius:999px;justify-content:center;align-items:center;margin:0 auto 16px;display:flex}.success h2{color:var(--ink);margin:0 0 4px;font-size:18px}.success p{color:var(--muted);margin:0 0 20px;font-size:14px}.toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.toolbar-count{color:var(--muted);align-items:center;gap:8px;font-size:14px;display:flex}.toolbar-count .mono{font-family:var(--mono)}.toolbar-actions{flex-wrap:wrap;gap:8px;display:flex}.chip{font-family:var(--sans);background:var(--card);border:1px solid var(--line);color:var(--ink);cursor:pointer;border-radius:10px;align-items:center;gap:6px;padding:8px 12px;font-size:12px;font-weight:500;transition:background .15s,border-color .15s;display:inline-flex}.chip:hover:not(:disabled){background:var(--bg-soft)}.chip:disabled{opacity:.5;cursor:default}.chip.danger{color:var(--danger);border-color:#e8b9c0}.chip.danger:hover:not(:disabled){background:var(--danger-soft)}.entry-stack>*+*{margin-top:16px}.entry{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}.entry-head{border-bottom:1px solid var(--line-soft);background:#fdf5f6;justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.entry-del{color:var(--faint);cursor:pointer;background:0 0;border:0;padding:2px}.entry-del:hover{color:var(--danger)}.entry-img-btn{cursor:zoom-in;background:#faf2f3;border:0;width:100%;padding:0;display:block}.entry-img-btn img{object-fit:contain;width:100%;max-height:320px;display:block}.entry-body{padding:12px 16px 14px}.entry-meta{font-family:var(--mono);color:var(--muted);align-items:center;gap:8px;margin-bottom:6px;font-size:12px;display:flex}.entry-meta .who{color:var(--ink);font-weight:600}.entry-meta .dot{color:var(--faint)}.entry-comment{color:var(--ink);white-space:pre-wrap;margin:0;font-size:14px;line-height:1.55}.entry-comment.empty{color:var(--faint);font-style:italic}.empty{background:var(--card);border-radius:var(--radius);text-align:center;border:1px dashed #e2c4c8;padding:72px 24px}.empty p{margin:0}.empty .empty-title{color:var(--ink);margin-bottom:4px;font-size:14px;font-weight:500}.empty .empty-hint{color:var(--faint);font-size:12px}.loading{color:var(--muted);justify-content:center;align-items:center;gap:8px;padding:80px 0;font-size:14px;display:flex}.login{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);text-align:center;max-width:360px;margin:0 auto;padding:28px}.login-icon{background:var(--accent-soft);width:48px;height:48px;color:var(--accent);border-radius:999px;justify-content:center;align-items:center;margin:0 auto 16px;display:flex}.login h2{color:var(--ink);margin:0 0 4px;font-size:16px}.login p{color:var(--muted);margin:0 0 16px;font-size:14px}.login .input{text-align:center;margin-bottom:12px}.login .err{color:var(--danger);margin:-4px 0 12px;font-size:12px}.lightbox{z-index:50;background:#3c2c2fdb;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.lightbox img{object-fit:contain;border-radius:12px;max-width:100%;max-height:100%}.lightbox-close{color:#fff;cursor:pointer;background:#ffffff2e;border:0;border-radius:999px;justify-content:center;align-items:center;width:40px;height:40px;display:flex;position:absolute;top:16px;right:16px}.lightbox-close:hover{background:#ffffff47}.spin{animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}@media (prefers-reduced-motion:reduce){*{transition:none!important}.spin{animation:none}}
