:root{--bg:#f4f6f8;--card:#fff;--ink:#0f172a;--muted:#64748b;--faint:#94a3b8;--line:#e2e8f0;--line-soft:#eef2f6;--accent:#0f766e;--accent-strong:#115e59;--accent-soft:#f0fdfa;--danger:#dc2626;--danger-soft:#fef2f2;--radius:16px;--mono:ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;--sans:system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif}*{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:10px;display:flex}.brand-badge{background:var(--accent);color:#fff;border-radius:11px;flex:none;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.brand-title{letter-spacing:-.01em;margin:0;font-size:20px;font-weight:700;line-height:1}.brand-sub{font-family:var(--mono);color:var(--muted);letter-spacing:.04em;margin:5px 0 0;font-size:11px}.tabs{background:var(--card);border:1px solid var(--line);border-radius:12px;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:9px;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(--ink);color:#fff}.notice{color:#92400e;background:#fffbeb;border:1px solid #fcd34d;border-radius:12px;margin-bottom:20px;padding:12px 16px;font-size:14px;line-height:1.5}.field-label{color:#334155;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 #0f766e1f}.input.error,.textarea.error{border-color:#fca5a5}.input.error:focus{box-shadow:0 0 0 3px #dc26261f}.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 #cbd5e1;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:#334155;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:#f1f5f9;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(--ink);border-radius:5px;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:#0000008c;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:#000000bf}.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(--ink);color:#fff}.btn-dark:hover:not(:disabled){background:#1e293b}.btn-dashed{background:var(--card);width:100%;color:var(--muted);border:1px dashed #cbd5e1;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 #99f6e4;padding:36px 24px}.success-icon{width:48px;height:48px;color:var(--accent);background:#ccfbf1;border-radius:999px;justify-content:center;align-items:center;margin:0 auto 16px;display:flex}.success h2{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:#334155;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:#f8fafc}.chip:disabled{opacity:.5;cursor:default}.chip.danger{color:var(--danger);border-color:#fecaca}.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);justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.entry-del{color:#cbd5e1;cursor:pointer;background:0 0;border:0;padding:2px}.entry-del:hover{color:var(--danger)}.entry-img-btn{cursor:zoom-in;background:#f1f5f9;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:#334155;font-weight:600}.entry-meta .dot{color:#cbd5e1}.entry-comment{color:#1e293b;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 #cbd5e1;padding:72px 24px}.empty p{margin:0}.empty .empty-title{color:#334155;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{width:48px;height:48px;color:var(--muted);background:#f1f5f9;border-radius:999px;justify-content:center;align-items:center;margin:0 auto 16px;display:flex}.login h2{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:#000000d9;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.lightbox img{object-fit:contain;border-radius:10px;max-width:100%;max-height:100%}.lightbox-close{color:#fff;cursor:pointer;background:#ffffff26;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:#ffffff40}.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}}
