@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){:root,:host{--accent:#7c3aed}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--radius-lg:.5rem;--radius-xl:.75rem;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.hidden{display:none}.rounded{border-radius:.25rem}}:root{--bg:#f5f5f7;--surface:#fff;--surface-2:#f0f0f5;--border:#e0e0ea;--border-2:#c8c8d8;--ink:#1a1a2e;--ink-dim:#6e6e8a;--accent:#7c3aed;--accent-2:#6d28d9;--accent-glow:#7c3aed28;--accent-light:#ede9fe;--success:#059669;--warning:#d97706;--warning-bg:#fef3c7;--danger:#dc2626;--radius:8px;--radius-lg:12px;--radius-xl:16px;--font-sans:"Inter", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace}@property --accent{syntax:"<color>";inherits:true;initial-value:#7c3aed}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{color-scheme:light;font-size:14px}body{background:var(--bg);color:var(--ink);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;min-height:100dvh;line-height:1.5}.app-shell{gap:28px;max-width:1100px;margin-inline:auto;padding:24px 20px 56px;display:grid}.app-header{border-bottom:1px solid var(--border);padding-bottom:20px}.app-title{color:var(--ink);letter-spacing:-.03em;font-size:1.5rem;font-weight:700}.app-title span{color:var(--accent)}.app-subtitle{color:var(--ink-dim);margin-top:4px;font-size:.88rem}.app-layout{grid-template-columns:360px 1fr;align-items:start;gap:24px;display:grid}@media(max-width:820px){.app-layout{grid-template-columns:1fr}}.panel-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:20px}.panel-title{text-transform:uppercase;letter-spacing:.08em;color:var(--ink-dim);margin-bottom:14px;font-size:.72rem;font-weight:600}.mode-tabs{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);grid-template-columns:repeat(4,1fr);gap:2px;margin-bottom:20px;padding:3px;display:grid}.mode-tab{color:var(--ink-dim);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:7px 0;font-size:.8rem;font-weight:500;transition:background .15s,color .15s}.mode-tab:hover{color:var(--ink);background:var(--surface)}.mode-tab[aria-selected=true]{background:var(--surface);color:var(--accent);font-weight:600;box-shadow:0 1px 3px #00000014}.mode-tab:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.mode-panel{gap:12px;display:grid}.field-group{gap:5px;display:grid}.field-label{color:var(--ink);font-size:.8rem;font-weight:500}.field-input,.field-select,.field-textarea{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--ink);font-family:var(--font-sans);width:100%;padding:9px 11px;font-size:.85rem;transition:border-color .15s,box-shadow .15s}:is(.field-input,.field-select,.field-textarea):focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);outline:none}:is(.field-input,.field-select,.field-textarea)::placeholder{color:var(--ink-dim);opacity:.7}.field-textarea{resize:vertical;min-height:80px}.field-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236e6e8a' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right 11px center;background-repeat:no-repeat;padding-right:30px}.field-check-row{color:var(--ink);cursor:pointer;align-items:center;gap:8px;font-size:.83rem;display:flex}.field-check-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.style-section{border-top:1px solid var(--border);gap:14px;margin-top:20px;padding-top:20px;display:grid}.color-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.color-field{gap:5px;display:grid}.color-input-wrap{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:8px;padding:5px 8px;transition:border-color .15s;display:flex}.color-input-wrap:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.color-swatch{cursor:pointer;border:none;border-radius:4px;flex-shrink:0;width:28px;height:28px;padding:0}.color-swatch::-webkit-color-swatch-wrapper{padding:0}.color-swatch::-webkit-color-swatch{border:none;border-radius:3px}.color-hex{color:var(--ink);font-family:var(--font-mono);background:0 0;border:none;flex:1;width:72px;min-width:0;font-size:.8rem}.color-hex:focus{outline:none}.contrast-warning{background:var(--warning-bg);border-radius:var(--radius);color:var(--warning);border:1px solid #fbbf24;padding:8px 11px;font-size:.78rem;line-height:1.5}.style-label{color:var(--ink);margin-bottom:6px;font-size:.8rem;font-weight:500}.radio-group{gap:8px;display:flex}.radio-btn{border:1px solid var(--border);border-radius:var(--radius);color:var(--ink-dim);cursor:pointer;background:var(--bg);flex:1;justify-content:center;align-items:center;gap:5px;padding:8px 4px;font-size:.78rem;transition:border-color .15s,color .15s,background .15s;display:flex}.radio-btn input[type=radio]{display:none}.radio-btn:has(input[type=radio]:checked){border-color:var(--accent);background:var(--accent-light);color:var(--accent);font-weight:600}.radio-btn:hover:not(:has(input[type=radio]:checked)){border-color:var(--border-2);color:var(--ink)}.radio-btn:focus-within{outline:2px solid var(--accent);outline-offset:2px}.logo-section{gap:8px;display:grid}.logo-note{color:var(--ink-dim);font-size:.76rem;font-style:italic}.logo-controls{gap:8px;display:grid}.logo-size-row{color:var(--ink-dim);align-items:center;gap:10px;font-size:.78rem;display:flex}.logo-size-row input[type=range]{accent-color:var(--accent);flex:1}.ec-note{color:var(--accent);font-size:.76rem;font-weight:500}.preview-col{gap:16px;display:grid;position:sticky;top:24px}.qr-preview-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);flex-direction:column;align-items:center;gap:20px;padding:24px;display:flex}#qr-preview{justify-content:center;align-items:center;width:100%;min-height:240px;display:flex}#qr-preview svg{border-radius:var(--radius);width:100%;max-width:280px;height:auto;max-height:280px}.qr-placeholder,.qr-error{border:2px dashed var(--border-2);border-radius:var(--radius-lg);width:240px;height:240px;color:var(--ink-dim);text-align:center;justify-content:center;align-items:center;padding:20px;font-size:.83rem;display:flex}.download-row{grid-template-columns:1fr 1fr;gap:10px;width:100%;display:grid}.btn{border-radius:var(--radius);cursor:pointer;border:none;justify-content:center;align-items:center;gap:6px;padding:9px 14px;font-size:.82rem;font-weight:500;transition:background .15s,color .15s,box-shadow .15s;display:inline-flex}.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-2)}.btn-primary:active{box-shadow:0 0 0 3px var(--accent-glow)}.btn-outline{color:var(--accent);border:1px solid var(--accent);background:0 0}.btn-outline:hover{background:var(--accent-light)}.btn-ghost{color:var(--ink-dim);border:1px solid var(--border);background:0 0}.btn-ghost:hover{background:var(--surface-2);color:var(--ink)}.btn-sm{padding:6px 10px;font-size:.75rem}.batch-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:20px}.batch-header{justify-content:space-between;align-items:center;margin-bottom:0;display:flex}.batch-header-title{color:var(--ink);font-size:.9rem;font-weight:600}.batch-header-hint{color:var(--ink-dim);font-size:.78rem}.batch-body{gap:14px;margin-top:16px;display:grid}.batch-actions{gap:10px;display:flex}#batch-results{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px;margin-top:4px;display:grid}.batch-item{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--ink-dim);word-break:break-all;text-align:center;flex-direction:column;align-items:center;gap:8px;padding:12px;font-size:.75rem;display:flex}.batch-item svg{border-radius:4px;max-width:120px;height:auto}.batch-item-text{text-overflow:ellipsis;white-space:nowrap;max-width:120px;overflow:hidden}.file-input-btn{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);color:var(--ink-dim);cursor:pointer;align-items:center;gap:6px;padding:7px 12px;font-size:.8rem;transition:border-color .15s,color .15s;display:inline-flex}.file-input-btn input[type=file]{display:none}.file-input-btn:hover{border-color:var(--border-2);color:var(--ink)}@media(prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}
