:root{--sky-50:#f0f9ff;--sky-100:#e0f2fe;--sky-200:#bae6fd;--sky-300:#7dd3fc;--sky-400:#38bdf8;--sky-500:#0ea5e9;--sky-600:#0284c7;--sky-700:#0369a1;--sky-800:#075985;--sky-900:#0c4a6e;--white:#fff;--border:#bae6fd;--radius:8px}*{box-sizing:border-box}body{min-height:100vh;color:var(--sky-900);background:var(--sky-50);-webkit-font-smoothing:antialiased;margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:15px;line-height:1.5}.app{max-width:960px;margin:0 auto;padding:24px 20px}.header{text-align:center;margin-bottom:28px}.header h1{letter-spacing:-.02em;color:var(--sky-900);margin:0;font-size:1.75rem;font-weight:700}.main{grid-template-columns:1fr 1fr;align-items:start;gap:24px;display:grid}.controls-column{flex-direction:column;gap:24px;display:flex}@media (max-width:720px){.main{grid-template-columns:1fr}}.panel{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.controls .field+.field,.params .field+.field{margin-top:16px}.params{border:none;border-top:1px solid var(--border);margin:20px 0 0;padding:16px 0 0}.params legend{color:var(--sky-800);padding:0 6px 0 0;font-weight:600}label{color:var(--sky-800);margin-bottom:6px;font-weight:500;display:block}input[type=text],input[type=number],textarea,select{width:100%;font:inherit;color:var(--sky-900);background:var(--sky-50);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px}input[type=color]{border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;width:100%;height:40px;padding:4px}textarea{resize:vertical;min-height:72px}textarea::placeholder{color:var(--sky-700);opacity:.8}.hint,.preview-hint{color:var(--sky-700);margin-top:6px;font-size:.8rem;display:block}.upload-area{background:var(--sky-50);border:1px dashed var(--sky-300);border-radius:var(--radius);cursor:pointer;flex-wrap:wrap;align-items:center;gap:10px;padding:14px 16px;transition:background .15s,border-color .15s;display:flex}.upload-area:hover,.upload-area.dragover,.clear-logo:hover{background:var(--sky-100);border-color:var(--sky-400)}.upload-text{color:var(--sky-700);font-size:.9rem}.clear-logo{color:var(--sky-700);border:1px solid var(--sky-300);border-radius:var(--radius);cursor:pointer;background:0 0;margin-left:auto;padding:6px 12px;font-size:.85rem;font-weight:500}.presets-title{color:var(--sky-800);margin:0 0 12px;font-size:1rem;font-weight:600}.presets-panel .presets{flex-direction:column;gap:10px;display:flex}.preset-slot{background:var(--sky-50);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:10px;padding:10px 12px;display:flex}.preset-name{min-width:0;color:var(--sky-900);background:var(--white);border:1px solid var(--border);border-radius:var(--radius);flex:1;padding:6px 10px;font-size:.9rem}.preset-name::placeholder{color:var(--sky-700);opacity:.8}.preset-actions{flex-shrink:0;gap:8px;display:flex}.preset-load,.preset-save{min-width:5rem;color:var(--sky-700);background:var(--white);border:1px solid var(--sky-300);border-radius:var(--radius);cursor:pointer;box-sizing:border-box;padding:6px 12px;font-size:.85rem;font-weight:500}.preset-load:hover:not(:disabled),.preset-save:hover{background:var(--sky-100);border-color:var(--sky-400);color:var(--sky-800)}.preset-load:disabled{opacity:.5;cursor:not-allowed}.preset-load.preset-btn-feedback:disabled,.preset-save.preset-btn-feedback:disabled{opacity:1;cursor:default}.preset-btn-feedback{background:var(--sky-200)!important;border-color:var(--sky-500)!important;color:var(--sky-800)!important}.download-qr{color:var(--white);background:var(--sky-600);border:1px solid var(--sky-700);border-radius:var(--radius);cursor:pointer;padding:10px 20px;font-size:.95rem;font-weight:500;transition:background .15s,border-color .15s}.download-qr:hover{background:var(--sky-700);border-color:var(--sky-800)}.preview{position:sticky;top:24px}.preview-inner{flex-direction:column;align-items:center;gap:16px;display:flex}.canvas-wrap{background:var(--sky-50);border-radius:var(--radius);justify-content:center;align-items:center;min-height:300px;padding:16px;display:flex;position:relative}.canvas-wrap canvas,.canvas-wrap svg{max-width:100%;height:auto;display:block}.spinner{border-radius:var(--radius);background:#f0f9ffd9;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.spinner[hidden]{display:none}.spinner:after{content:"";border:3px solid var(--sky-200);border-top-color:var(--sky-600);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spinner}@keyframes spinner{to{transform:rotate(360deg)}}.preview-hint{margin:0}.footer{text-align:center;color:var(--sky-700);background:var(--sky-100);border:1px solid var(--border);border-radius:var(--radius);margin-top:40px;padding:20px 24px;font-size:.85rem}.footer p{margin:0}.footer p+p{margin-top:8px}.footer a{color:var(--sky-700);font-weight:500;text-decoration:none}.footer a:hover{color:var(--sky-800);text-decoration:underline}
