:root{--bg: #1e1e2f;--panel: #2a2a3d;--accent: #5eead4;--danger: #ff4d4d;--text: #f5f5f5;--muted: #b0b0b0}*{box-sizing:border-box}html,body{margin:0;height:100%;font-family:Segoe UI,sans-serif;color:var(--text);background:var(--bg)}.app{display:grid;grid-template-areas:"header header" "sidebar viewer" "footer footer";grid-template-columns:320px 1fr;grid-template-rows:auto 1fr auto;min-height:100vh;gap:12px;padding:12px}header.header{grid-area:header;display:flex;flex-wrap:wrap;align-items:center;gap:12px}header .logo{font-weight:700;font-size:1.3rem;color:var(--accent)}.language-selector{margin-left:auto;display:flex;flex-direction:column;gap:4px}.language-selector label{font-size:.75rem;color:var(--muted)}.language-selector select{background:var(--panel);color:var(--text);border-radius:8px;border:1px solid #444;padding:6px 10px}.input-file{background:var(--panel);color:var(--text);border-radius:8px;padding:6px 10px;border:none;cursor:pointer}.controls{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.btn{background:var(--panel);color:var(--text);border:1px solid #444;border-radius:8px;padding:6px 10px;cursor:pointer;transition:.2s}.btn:hover{border-color:var(--accent)}.btn.danger{background:var(--danger);color:#fff;border:none}.btn.danger:hover{opacity:.8}.page-indicator{padding:2px 6px;background:#333;border-radius:6px;font-size:.9rem}.sidebar{grid-area:sidebar;background:var(--panel);border-radius:12px;padding:12px;overflow:auto}.sidebar h4{margin-top:0;color:var(--accent)}.sidebar .sidebar-actions{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.sidebar .json-editor{width:100%;min-height:220px;border-radius:8px;border:1px solid #444;background:#1d1d2a;color:var(--text);padding:10px;font-family:Fira Code,monospace;font-size:.85rem;resize:vertical}.sidebar .json-editor:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #5eead426}.sidebar .sidebar-hint{display:block;margin-top:8px;font-size:.75rem;color:var(--muted);line-height:1.4}.sidebar .templates{margin-top:16px;padding-top:12px;border-top:1px solid #3a3a4f;display:flex;flex-direction:column;gap:10px}.sidebar .templates h5{margin:0;font-size:1rem;color:var(--text)}.sidebar .templates__save{display:flex;flex-wrap:wrap;gap:8px}.sidebar .templates__save input{flex:1;min-width:0;background:#1d1d2a;color:var(--text);border-radius:8px;border:1px solid #444;padding:6px 10px}.sidebar .templates__save input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #5eead426}.sidebar .templates__select label{display:block;font-size:.75rem;color:var(--muted);margin-bottom:4px}.sidebar .templates__controls{display:flex;flex-wrap:wrap;gap:6px}.sidebar .templates__controls select{flex:1;min-width:0;background:#1d1d2a;color:var(--text);border-radius:8px;border:1px solid #444;padding:6px 10px}.sidebar .templates__controls select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #5eead426}.sidebar .templates__empty{margin:0;font-size:.8rem;color:var(--muted)}.templates__delete{border-color:var(--danger);color:var(--danger);background:transparent}.templates__delete:hover{background:#ff4d4d26;border-color:var(--danger)}.viewer{grid-area:viewer;background:var(--panel);border-radius:12px;overflow:auto;display:flex;justify-content:center;align-items:flex-start;padding:12px}.footer{grid-area:footer;background:var(--panel);border-radius:12px;padding:12px 16px;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;font-size:.9rem}.footer__brand{display:flex;align-items:center;gap:12px}.footer__logo{width:40px;height:40px}.footer__brand-text{display:flex;flex-direction:column;gap:4px}.footer__app-name{font-weight:600;color:var(--accent)}.footer__version{font-size:.8rem;color:var(--muted)}.footer__details{display:flex;flex-direction:column;gap:4px;text-align:right;color:var(--muted)}.canvas-container{position:relative}#pdfCanvas,#overlayCanvas{display:block}#overlayCanvas{position:absolute;inset:0;pointer-events:none;z-index:1}.annotations-layer{position:absolute;inset:0;z-index:15;pointer-events:none}.hitbox{position:absolute;inset:0;cursor:crosshair;z-index:5}.annotation{position:absolute;pointer-events:auto;cursor:grab;background:#ffffff26;padding:2px 4px;border-radius:4px;white-space:nowrap;transition:.2s;font-family:"Helvetica, Arial, sans-serif";font-weight:400;letter-spacing:0;line-height:1;-webkit-user-select:none;user-select:none}.annotation:hover{background:#5eead440;border:1px dashed var(--accent)}.annotation.dragging{cursor:grabbing}.annotation-editor{position:absolute;z-index:20;background:linear-gradient(180deg,#222234f5,#181828f5);padding:14px;border:1px solid rgba(94,234,212,.25);border-radius:8px;display:flex;flex-direction:column;gap:8px;min-width:260px;box-shadow:0 14px 30px #00000047;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.annotation-editor input[type=text],.annotation-editor input[type=number],.annotation-editor select{border-radius:4px;border:1px solid rgba(94,234,212,.25);padding:6px;background:#1e1e2fe6;color:var(--text);font-size:.9rem}.annotation-editor input[type=number],.annotation-editor select{width:100%}.annotation-editor input[type=color]{width:44px;height:36px;border:1px solid rgba(94,234,212,.35);border-radius:6px;padding:0;background:transparent;cursor:pointer}.annotation-editor button{cursor:pointer;border:none;border-radius:6px;padding:6px 10px;font-size:.9rem;background:var(--accent);color:#0b1f1f;transition:transform .1s ease}.annotation-editor button:hover{transform:translateY(-1px)}.annotation-editor.editing{border-color:#5eead4a6;box-shadow:0 18px 36px #00000059,0 0 0 1px #5eead440}.annotation-editor.editing:before{content:"";position:absolute;inset:0;border-radius:8px;padding:1px;background:linear-gradient(135deg,rgba(94,234,212,.45),transparent 70%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}.annotation-editor .field{display:flex;flex-direction:column;gap:4px}.annotation-editor .field-small{max-width:120px}.annotation-editor .field-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--accent)}.annotation-editor .color-section{display:flex;flex-direction:column;gap:6px}.annotation-editor .color-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.annotation-editor .color-inputs{display:flex;flex-wrap:wrap;gap:6px;min-width:200px}.annotation-editor .color-inputs input[type=text]{flex:1 1 120px;font-family:JetBrains Mono,Fira Code,monospace}.annotation-editor .color-hint{font-size:.7rem;color:var(--muted);line-height:1.3}.annotation-editor .editor-badge{align-self:flex-start;font-size:.7rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;background:#5eead433;color:var(--accent);border-radius:999px;padding:4px 10px}.annotation-editor.editing .editor-badge{background:var(--accent);color:#061111;box-shadow:0 4px 12px #5eead459}.annotation-editor .color-hint code{background:#5eead41a;padding:0 4px;border-radius:4px}.annotation-editor .editor-actions{display:flex;gap:6px;justify-content:flex-start}.annotation-editor .editor-actions .action-primary{margin-left:auto}.btn-delete{background:var(--danger);color:#fff;padding:6px 10px;border-radius:6px;cursor:pointer;border:none;font-size:.9rem}.btn-delete:hover{opacity:.8}.empty{display:flex;justify-content:center;align-items:center}.empty-text{color:var(--muted);font-size:1rem;text-align:center;max-width:400px}
