*,*:before,*:after{box-sizing:border-box}:root{--bg: #ffffff;--fg: #111827;--muted: #6b7280;--border: #e5e7eb;--btn-bg: transparent;--btn-fg: #374151;--btn-hover: #f3f4f6;--accent-bg: #111827;--accent-fg: #ffffff;--error: #b91c1c;--input-bg: #ffffff;--input-border: #d1d5db;color-scheme:light}html[data-theme=dark]{--bg: #0b0b0d;--fg: #e8e8ea;--muted: #9ca3af;--border: #1f2023;--btn-bg: transparent;--btn-fg: #d1d5db;--btn-hover: #1b1c1f;--accent-bg: #e8e8ea;--accent-fg: #0b0b0d;--error: #f87171;--input-bg: #15161a;--input-border: #2a2c31;color-scheme:dark}html,body,#root{height:100%;margin:0;background:var(--bg);color:var(--fg)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;-webkit-text-size-adjust:100%}.app{display:flex;flex-direction:column;height:100vh;height:100dvh;height:var(--vvh, 100dvh);background:var(--bg)}.header{display:flex;align-items:center;gap:4px;padding:6px 8px;border-bottom:1px solid var(--border);flex:0 0 auto}.spacer{flex:1}.icon-btn{background:var(--btn-bg);border:0;padding:6px 10px;font-size:18px;line-height:1;cursor:pointer;color:var(--btn-fg);border-radius:6px;transition:background .12s ease}.icon-btn:hover{background:var(--btn-hover)}.icon-btn:active{opacity:.6}.icon-btn:disabled{opacity:.5;cursor:default}.icon-btn.spinning{animation:notepad-spin .8s linear infinite}.icon-btn.pulsing{animation:notepad-pulse 1.1s ease-in-out infinite}@keyframes notepad-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes notepad-pulse{0%,to{opacity:1}50%{opacity:.35}}.error-badge{color:var(--accent-fg);background:var(--error);font-size:11px;font-weight:600;padding:2px 6px;border-radius:999px;margin-right:2px;cursor:help}.slot-group{display:inline-flex;gap:4px;padding:0 6px;margin-left:4px}.slot-btn{background:var(--btn-bg);border:1px solid var(--border);color:var(--btn-fg);font-weight:600;font-size:13px;min-width:34px;height:30px;padding:0 8px;border-radius:8px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .12s ease,color .12s ease,border-color .12s ease;font-family:inherit}.slot-btn:hover{background:var(--btn-hover)}.slot-btn:active{opacity:.6}.slot-btn.active{background:var(--accent-bg);color:var(--accent-fg);border-color:var(--accent-bg)}.slot-btn.unassigned{opacity:.4;border-style:dashed}.editor{flex:1 1 auto;min-height:0;width:100%;border:0;outline:0;resize:none;padding:16px 16px 40vh;font:17px/1.45 -apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--fg);background:var(--bg);caret-color:var(--fg);overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;scroll-padding-bottom:25vh}.editor::placeholder{color:var(--muted)}.hash-filter{flex:1 1 auto;min-height:0;display:flex;flex-direction:column;background:var(--bg);overflow:hidden}.hash-filter-meta{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;border-bottom:1px solid var(--border);font-size:12px;color:var(--muted);flex:0 0 auto}.hash-filter-exit{background:var(--btn-hover);color:var(--fg);border:0;padding:6px 10px;border-radius:6px;font:12px/1 inherit;cursor:pointer}.hash-filter-exit:hover{opacity:.85}.hash-filter-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:14px}.hash-filter-list{list-style:none;margin:0;padding:4px 0;overflow-y:auto;flex:1 1 auto;-webkit-overflow-scrolling:touch}.hash-filter-list li{margin:0}.hash-filter-line{display:grid;grid-template-columns:36px 1fr;gap:12px;align-items:baseline;width:100%;text-align:left;background:transparent;border:0;padding:10px 16px;cursor:pointer;color:var(--fg);font:16px/1.5 -apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}.hash-filter-line:hover{background:var(--btn-hover)}.hash-filter-line:active{opacity:.7}.hash-filter-num{color:var(--muted);font-size:11px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;text-align:right;-webkit-user-select:none;user-select:none}.hash-filter-text{white-space:pre-wrap;word-break:break-word;overflow-wrap:anywhere}.hash-filter-warn{color:var(--muted)}.hash-filter-error{padding:8px 16px;color:var(--error);font-size:13px;border-bottom:1px solid var(--border)}.hash-filter-scroll{flex:1 1 auto;overflow-y:auto;-webkit-overflow-scrolling:touch}.hash-filter-group{border-bottom:1px solid var(--border)}.hash-filter-group:last-child{border-bottom:0}.hash-filter-group-header{display:flex;align-items:center;gap:10px;padding:10px 16px 4px;font-size:12px;color:var(--muted);position:sticky;top:0;background:var(--bg);z-index:1}.hash-filter-group-label{display:inline-flex;align-items:center;justify-content:center;min-width:26px;height:22px;padding:0 8px;border-radius:6px;background:var(--accent-bg);color:var(--accent-fg);font-weight:600;font-size:11px}.hash-filter-group-name{flex:1;color:var(--fg);font-weight:500}.hash-filter-group-count{color:var(--muted);font-size:11px}.hash-filter-empty-row{padding:6px 16px 12px;color:var(--muted);font-size:13px}.setup{display:flex;flex-direction:column;justify-content:center;gap:14px;padding:24px;max-width:420px;margin:0 auto;width:100%;flex:1}.setup h1{font-size:18px;font-weight:600;margin:0;color:var(--fg)}.setup p{margin:0;color:var(--muted);font-size:14px;line-height:1.45}.setup input{font:15px/1.3 inherit;padding:10px 12px;border:1px solid var(--input-border);border-radius:8px;outline:0;background:var(--input-bg);color:var(--fg)}.setup input:focus{border-color:var(--fg)}.setup button{font:15px/1 inherit;padding:10px 14px;border:0;border-radius:8px;cursor:pointer}.setup button.primary{background:var(--accent-bg);color:var(--accent-fg)}.setup button.primary:disabled{opacity:.4;cursor:not-allowed}.setup button.secondary{background:var(--btn-hover);color:var(--fg)}.setup-sep{border:0;border-top:1px solid var(--border);margin:12px 0 4px}.setup-h2{font-size:14px;font-weight:600;margin:0;color:var(--fg)}.setup .muted{color:var(--muted);font-size:13px}.setup .error{color:var(--error);font-size:13px}.page-select{font:15px/1.3 inherit;padding:10px 32px 10px 12px;border:1px solid var(--input-border);border-radius:8px;outline:0;background:var(--input-bg);color:var(--fg);-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);background-position:calc(100% - 18px) 50%,calc(100% - 12px) 50%;background-size:6px 6px,6px 6px;background-repeat:no-repeat}.page-select:focus{border-color:var(--fg)}.slots-grid{display:flex;flex-direction:column;gap:8px}.slot-row{display:grid;grid-template-columns:110px 1fr;align-items:center;gap:10px}.slot-row-label{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--fg);-webkit-user-select:none;user-select:none}.slot-row-key{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;background:var(--accent-bg);color:var(--accent-fg);font-weight:600;font-size:13px}.slot-row-name{color:var(--muted);font-size:12px}.ocr-label{display:flex;flex-direction:column;gap:4px}.ocr-label .muted{font-size:12px;color:var(--muted)}.ocr-actions{display:flex;gap:8px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;padding:16px;z-index:10}.modal{background:var(--bg);color:var(--fg);border:1px solid var(--border);border-radius:12px;padding:18px;max-width:720px;width:100%;max-height:90vh;overflow:auto;box-shadow:0 20px 60px #0006}.modal h2{margin:0 0 6px;font-size:16px;font-weight:600}.modal p{margin:0 0 14px;color:var(--muted);font-size:14px;line-height:1.45}.diff{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}@media (max-width: 640px){.diff{grid-template-columns:1fr}}.diff-label{font-size:12px;color:var(--muted);margin-bottom:4px}.diff pre{background:var(--input-bg);border:1px solid var(--border);border-radius:8px;padding:10px 12px;margin:0;max-height:300px;overflow:auto;font-size:12px;line-height:1.45;white-space:pre-wrap;word-break:break-word;color:var(--fg);font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.modal-actions{display:flex;gap:8px;justify-content:flex-end}.modal-actions button{font:15px/1 inherit;padding:10px 16px;border:0;border-radius:8px;cursor:pointer}.modal-actions button.primary{background:var(--accent-bg);color:var(--accent-fg)}.modal-actions button.secondary{background:var(--btn-hover);color:var(--fg)}
