:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{text-align:left;box-sizing:border-box;flex-direction:column;width:100%;max-width:100%;min-height:100svh;margin:0;display:flex}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}*{box-sizing:border-box}body{background:#f5f5f5;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif}.pdf-generator{flex-direction:column;height:100vh;min-height:100vh;display:flex;overflow:hidden}.pdf-generator-header{color:#fff;background:#1a1a2e;padding:1rem 2rem}.pdf-generator-header h1{margin:0;font-size:1.5rem}.pdf-generator-layout{flex:1;gap:1rem;min-height:0;padding:1rem;display:flex;overflow:hidden}.pdf-generator-sidebar{flex-direction:column;flex-shrink:0;gap:1rem;width:320px;max-height:100%;display:flex;overflow-y:auto}.pdf-generator-preview{background:#fff;border-radius:8px;flex:1;min-height:0;overflow:hidden;box-shadow:0 2px 8px #0000001a}.pdf-preview-empty{color:#666;justify-content:center;align-items:center;height:100%;font-size:1.1rem;display:flex}.qr-uploader{background:#fff;border-radius:8px;padding:1rem;box-shadow:0 2px 8px #0000001a}.qr-uploader h3{color:#333;margin:0 0 .75rem;font-size:1rem;font-weight:600}.qr-uploader input[type=file]{cursor:pointer;border:2px dashed #ccc;border-radius:4px;width:100%;padding:.5rem}.qr-uploader input[type=file]:hover{border-color:#666}.image-list{max-height:200px;margin-top:.75rem;overflow-y:auto}.image-item{background:#f9f9f9;border-radius:4px;align-items:center;gap:.5rem;margin-bottom:.5rem;padding:.5rem;display:flex}.image-item img{object-fit:cover;border-radius:4px}.image-name{text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.85rem;overflow:hidden}.remove-btn{color:#fff;cursor:pointer;background:#e74c3c;border:none;border-radius:50%;width:24px;height:24px;font-size:1rem;line-height:1}.remove-btn:hover{background:#c0392b}.image-actions{color:#666;justify-content:space-between;align-items:center;margin-top:.5rem;font-size:.85rem;display:flex}.image-actions button{color:#fff;cursor:pointer;background:#666;border:none;border-radius:4px;padding:.25rem .75rem;font-size:.8rem}.image-actions button:hover{background:#444}.config-panel{background:#fff;border-radius:8px;padding:1rem;box-shadow:0 2px 8px #0000001a}.config-panel h3{color:#333;margin:0 0 .75rem;font-size:1rem;font-weight:600}.config-panel h3:not(:first-child){margin-top:1rem}.config-row{gap:.75rem;display:flex}.config-panel label{color:#666;flex-direction:column;flex:1;gap:.25rem;min-width:0;font-size:.85rem;display:flex}.config-panel input[type=number]{box-sizing:border-box;border:1px solid #ddd;border-radius:4px;width:100%;min-width:0;padding:.5rem;font-size:.9rem}.config-panel input[type=number]:focus{border-color:#3498db;outline:none}.download-btn{color:#fff;cursor:pointer;text-align:center;background:#27ae60;border:none;border-radius:8px;width:100%;padding:1rem;font-size:1rem;font-weight:600;text-decoration:none;display:block}.download-btn:hover:not(:disabled){background:#219a52}.download-btn:disabled{cursor:not-allowed;background:#bdc3c7}
