:root{--font-sans: "Inter", "SF Pro Text", "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-mono: "JetBrains Mono", "SFMono-Regular", "Menlo", "Consolas", "Liberation Mono", "Courier New", monospace;--color-primary: #0ea5e9;--color-primary-strong: #0284c7;--color-primary-soft: #38bdf8;--color-primary-light: #e0f2fe;--color-primary-muted: #f0f9ff;--color-background: #f8fafc;--color-background-alt: #f1f5f9;--color-surface: #ffffff;--color-surface-alt: #f8fafc;--color-surface-muted: #f1f5f9;--color-surface-elevated: #ffffff;--color-accent: #6366f1;--color-accent-soft: #818cf8;--color-accent-light: #e0e7ff;--color-success: #10b981;--color-success-soft: #34d399;--color-success-light: #d1fae5;--color-danger: #ef4444;--color-danger-soft: #f87171;--color-danger-light: #fee2e2;--color-warning: #f59e0b;--color-warning-soft: #fbbf24;--color-warning-light: #fef3c7;--color-border: #e2e8f0;--color-border-strong: #cbd5e1;--color-border-soft: #f1f5f9;--text-strong: #0f172a;--text-default: #1e293b;--text-muted: #64748b;--text-placeholder: #94a3b8;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .04);--shadow-md: 0 4px 20px rgba(15, 23, 42, .08);--shadow-lg: 0 12px 40px rgba(15, 23, 42, .12);--shadow-xl: 0 24px 60px rgba(15, 23, 42, .16);--shadow-glow: 0 0 40px rgba(14, 165, 233, .15);--shadow-glow-strong: 0 0 60px rgba(14, 165, 233, .25);--fs-xs: .75rem;--fs-sm: .8125rem;--fs-md: .875rem;--fs-base: .9375rem;--fs-lg: 1rem;--fs-xl: 1.125rem;--fs-2xl: 1.25rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-2xl: 28px;--tag-payment: #10b981;--tag-payment-bg: rgba(16, 185, 129, .1);--tag-metadata: #f59e0b;--tag-metadata-bg: rgba(245, 158, 11, .1);--tag-crc: #ef4444;--tag-crc-bg: rgba(239, 68, 68, .1);--drawer-width: 420px;--drawer-width-mobile: 100%;color-scheme:light}*{box-sizing:border-box}html{font-size:15px}body{margin:0;font-family:var(--font-sans);font-size:var(--fs-base);background:linear-gradient(180deg,var(--color-background) 0%,var(--color-background-alt) 100%);background-attachment:fixed;color:var(--text-default);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6}#root{min-height:100vh}code{font-family:var(--font-mono)}::selection{background:#0ea5e933;color:var(--color-primary-strong)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-surface-muted);border-radius:4px}::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-primary-soft)}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.App{min-height:100vh;background:var(--color-background);display:flex;flex-direction:column}.App-header{position:sticky;top:0;z-index:100;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--color-border);padding:.75rem 1rem}.header-content{max-width:980px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:1.5rem}.header-brand{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.brand-icon{width:36px;height:36px;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--color-primary),var(--color-accent));color:#fff;display:grid;place-items:center}.brand-icon svg{width:20px;height:20px}.header-brand h1{margin:0;font-size:var(--fs-lg);font-weight:700;color:var(--text-strong);letter-spacing:-.01em}.main-nav{display:flex;align-items:center;gap:.25rem;padding:.25rem;background:var(--color-surface-alt);border-radius:var(--radius-lg);border:1px solid var(--color-border)}.nav-tab{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:var(--radius-md);border:none;background:transparent;color:var(--text-muted);font-weight:600;font-size:var(--fs-sm);cursor:pointer;transition:all .2s ease}.nav-tab:hover{color:var(--text-default);background:#ffffff80}.nav-tab svg{width:16px;height:16px}.history-toggle-button{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);color:var(--text-muted);cursor:pointer;transition:all .2s ease;position:relative;flex-shrink:0}.history-toggle-button:hover{color:var(--color-primary);background:var(--color-surface-alt);border-color:var(--color-primary)}.history-count-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;border-radius:999px;background:var(--color-primary);color:#fff;font-size:.65rem;font-weight:700;display:grid;place-items:center}.App-main{flex:1;padding:1.25rem 1rem 2rem;display:flex;justify-content:center}.scanner-section,.generator-section{width:100%;max-width:980px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:none;padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.section-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:1.5rem}.section-heading h2{margin:0 0 .35rem;font-size:clamp(1.25rem,2.8vw,1.8rem);font-weight:800;letter-spacing:-.015em;color:var(--text-strong)}.section-heading p{margin:0;color:var(--text-muted);font-size:var(--fs-base);max-width:560px;line-height:1.55}.scanner-section .section-heading h2{font-size:clamp(1.12rem,2vw,1.35rem);margin-bottom:.2rem}.scanner-section .section-heading p{font-size:var(--fs-md);line-height:1.4}.section-tag{align-self:flex-start;padding:.35rem .75rem;border-radius:999px;background:#2563eb1f;color:var(--color-primary);font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.input-methods{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem;align-items:stretch}.error-message{display:inline-flex;align-items:center;gap:.75rem;padding:.85rem 1.1rem;border-radius:14px;background:#ef444414;color:var(--color-danger);border:1px solid rgba(239,68,68,.25);font-weight:600;margin-top:-.5rem}.error-icon{width:18px;height:18px}.qr-scanner,.file-upload,.text-input{background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:1.25rem;display:flex;flex-direction:column;gap:1rem;min-height:100%;box-shadow:var(--shadow-sm);transition:transform .25s ease,box-shadow .25s ease}.qr-scanner:hover,.file-upload:hover,.text-input:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.scanner-meta{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.camera-select{display:flex;flex-direction:column;gap:.4rem;min-width:220px}.camera-select span{font-size:.8rem;letter-spacing:.05em;text-transform:uppercase;font-weight:700;color:var(--text-muted)}.camera-select select{border-radius:12px;border:1px solid var(--color-border);background:var(--color-surface);font-size:.95rem;padding:.55rem .85rem;color:var(--text-default);transition:border-color .2s ease,box-shadow .2s ease}.camera-select select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb26}.camera-select select:disabled{background:var(--color-surface-muted);color:var(--text-muted)}.scanner-meta-actions{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.camera-refresh-button{background:var(--color-surface);border:1px solid var(--color-border);color:var(--text-muted);font-size:.9rem;padding:.55rem .9rem;border-radius:12px;display:inline-flex;align-items:center;gap:.45rem;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,color .2s ease}.camera-refresh-button:hover{transform:translateY(-2px);color:var(--text-default);box-shadow:var(--shadow-md)}.camera-refresh-button:disabled,.camera-refresh-button:disabled:hover{opacity:.6;box-shadow:none;transform:none;cursor:not-allowed}.status-pill{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .8rem;border-radius:999px;border:1px solid var(--color-border);background:var(--color-surface);color:var(--text-muted);font-weight:600;font-size:.85rem}.status-pill:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.status-pill--live{background:#0f9d581f;border-color:#0f9d5840;color:var(--color-success)}.status-pill--attention{background:#ef44441f;border-color:#ef444440;color:var(--color-danger)}.status-pill--starting{background:#2563eb1f;border-color:#2563eb40;color:var(--color-primary)}.card-icon{width:48px;height:48px;border-radius:14px;display:grid;place-items:center;background:var(--color-surface);border:1px solid var(--color-border);box-shadow:inset 0 0 0 1px #94a3b82e}.card-icon.accent-camera{color:var(--color-primary);background:#2563eb1f;border-color:#2563eb40}.card-icon.accent-upload{color:#d97706;background:#d977061f;border-color:#d9770640}.card-icon.accent-text{color:var(--color-success);background:#0f9d581f;border-color:#0f9d5840}.card-icon.accent-result{color:var(--color-accent);background:#7c3aed1f;border-color:#7c3aed40}.card-icon.accent-generate{color:var(--color-primary);background:#2563eb1f;border-color:#2563eb40}.card-icon.accent-history{color:#ec4899;background:#ec48991f;border-color:#ec489940}.card-title{margin:0;font-size:var(--fs-lg);font-weight:700;letter-spacing:-.01em;color:var(--text-strong)}.card-subtitle{margin:.15rem 0 0;color:var(--text-muted);font-size:var(--fs-base);line-height:1.5}.icon{display:block}.icon-lg{width:48px;height:48px}.hidden-input{display:none}.inline-error{display:inline-flex;align-items:center;gap:.6rem;padding:.75rem 1rem;border-radius:14px;background:#ef444414;border:1px solid rgba(239,68,68,.25);color:var(--color-danger);font-weight:600}.scanner-controls{display:flex;justify-content:flex-start}.scan-button,.stop-button,.upload-button,.clear-button,.sample-button,.generate-button,.download-button,.copy-button,.clear-input-button,.clear-history-button,.delete-item-button,.close-button{display:inline-flex;align-items:center;justify-content:center;gap:.6rem;border-radius:14px;border:1px solid transparent;font-weight:600;font-size:.95rem;padding:.65rem 1.2rem;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background .2s ease,border-color .2s ease,color .2s ease}.scan-button,.generate-button,.upload-button{background:var(--color-primary);color:#fff;box-shadow:var(--shadow-sm)}.scan-button:hover,.generate-button:hover,.upload-button:hover{transform:translateY(-2px);background:var(--color-primary-strong);box-shadow:var(--shadow-md)}.stop-button{background:#ef44441f;border-color:#ef444440;color:var(--color-danger)}.stop-button:hover{transform:translateY(-2px);background:#ef44442e}.sample-button{background:#7c3aed1f;border-color:#7c3aed40;color:var(--color-accent)}.sample-button:hover{transform:translateY(-2px);background:#7c3aed2e}.clear-button,.clear-input-button,.download-button,.copy-button,.clear-history-button,.close-button{background:var(--color-surface);border-color:var(--color-border);color:var(--text-muted)}.close-button{width:40px;height:40px;padding:0}.close-button .icon{width:18px;height:18px}.clear-button:hover,.clear-input-button:hover,.download-button:hover,.copy-button:hover,.clear-history-button:hover,.close-button:hover{transform:translateY(-2px);color:var(--text-default);box-shadow:var(--shadow-md)}.delete-item-button{padding:.35rem;border-radius:10px;background:transparent;border:none;color:var(--text-muted)}button:disabled,button:disabled:hover{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.qr-reader-frame{position:relative;width:100%;max-width:520px;margin:0 auto;border-radius:18px;overflow:hidden;border:1px dashed var(--color-border);min-height:260px;background:var(--color-surface);display:flex;align-items:center;justify-content:center}.qr-reader-frame--active{border-style:solid;border-color:#2563eb59;box-shadow:inset 0 0 0 2px #2563eb1f}.scanner-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;text-align:center;color:var(--text-muted);padding:1.5rem;background:#ffffffeb;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.scanner-placeholder p{margin:0;font-size:.95rem}.scan-status{text-align:center;font-size:.9rem;color:var(--text-muted);font-weight:500}.upload-dropzone{display:flex;flex-direction:column;align-items:center;gap:.65rem;padding:1.75rem 1.25rem;border-radius:18px;border:2px dashed rgba(37,99,235,.35);background:#2563eb14;color:var(--color-primary);font-weight:600;cursor:pointer;transition:transform .2s ease,background .2s ease,border-color .2s ease}.upload-dropzone:hover,.upload-dropzone:focus-visible{transform:translateY(-3px);background:#2563eb1f;border-color:#2563eb8c}.dropzone-title{font-size:1.05rem}.dropzone-subtitle{font-size:.9rem;color:var(--text-muted);font-weight:500}.qr-textarea{width:100%;min-height:160px;padding:1.1rem 1.2rem;border-radius:14px;border:1px solid var(--color-border);background:var(--color-surface);font-family:var(--font-mono);font-size:.95rem;line-height:1.6;resize:vertical;transition:border-color .2s ease,box-shadow .2s ease}.qr-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb26}.qr-textarea::placeholder{color:#64748bb3}.input-controls{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:flex-start}.input-hint{margin:0;display:inline-flex;align-items:center;gap:.45rem;font-size:.85rem;color:var(--text-muted)}.qr-data-display{width:100%;max-width:980px;margin:0 auto;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:clamp(1.25rem,2.4vw,1.75rem);display:flex;flex-direction:column;gap:1.25rem}.data-header{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}.data-heading{display:flex;align-items:center;gap:1rem}.data-heading h2{margin:0;font-size:clamp(1.8rem,3vw,2.4rem);font-weight:800;letter-spacing:-.018em;color:var(--text-strong)}.data-subtitle{margin:.25rem 0 0;color:var(--text-muted);font-size:.95rem;max-width:460px;line-height:1.6}.summary-section,.raw-data-section,.parsed-fields-section{background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:22px;padding:1.75rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:1.25rem}.section-title{margin:0;display:inline-flex;align-items:center;gap:.65rem;font-size:1.05rem;font-weight:700;color:var(--text-strong)}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.summary-item{display:flex;flex-direction:column;gap:.35rem;background:var(--color-surface);border-radius:16px;border:1px solid var(--color-border);padding:1rem;box-shadow:var(--shadow-sm)}.summary-item label{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-weight:700}.summary-item span{font-family:var(--font-mono);font-size:.95rem;color:var(--text-default)}.raw-data{background:#0f172a;color:#e2e8f0;border-radius:16px;padding:1.25rem;border:1px solid #1e293b;overflow-x:auto}.raw-data code{display:block;font-size:.88rem;white-space:pre-wrap;word-break:break-word}.fields-info{margin:0;font-size:.9rem;color:var(--text-muted)}.fields-table{display:flex;flex-direction:column;gap:.85rem}.table-header{display:grid;grid-template-columns:80px 80px 1fr 1.2fr;gap:1rem;font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-weight:700;padding:0 .5rem}.summary-panel{display:flex;flex-wrap:wrap;gap:.75rem;flex:1}.summary-item{display:flex;flex-direction:column;gap:.25rem;padding:.75rem 1rem;background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-lg);min-width:120px;position:relative}.summary-item--primary{background:linear-gradient(135deg,#2563eb14,#7c3aed14);border-color:#2563eb33}.summary-item--highlight{background:linear-gradient(135deg,#10b9811a,#0596691a);border-color:#10b98140}.summary-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-weight:700}.summary-value{font-size:var(--fs-base);font-weight:600;color:var(--text-strong)}.summary-value--amount{font-size:var(--fs-lg);color:var(--color-success);font-weight:700}.summary-value--mono{font-family:var(--font-mono);font-size:var(--fs-sm)}.copy-btn{position:absolute;top:.5rem;right:.5rem;width:24px;height:24px;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--text-muted);cursor:pointer;display:grid;place-items:center;opacity:0;transition:all .2s ease}.summary-item:hover .copy-btn{opacity:1}.copy-btn:hover{background:var(--color-surface);color:var(--color-primary)}.field-group{border:1px solid var(--color-border);border-radius:16px;background:var(--color-surface);box-shadow:var(--shadow-sm);overflow:hidden;transition:border-color .2s ease,box-shadow .2s ease}.field-group.is-expanded{border-color:#7c3aed4d;box-shadow:0 6px 20px #7c3aed26}.table-row{display:grid;grid-template-columns:80px 80px 1fr 1.2fr;gap:1rem;align-items:center;padding:.85rem 1rem;background:var(--color-surface)}.tag{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-mono);font-weight:700;color:var(--color-primary)}.tag--payment .tag-value{background:var(--tag-payment-bg);border-color:#10b9814d;color:var(--tag-payment)}.tag--metadata .tag-value{background:var(--tag-metadata-bg);border-color:#f59e0b4d;color:var(--tag-metadata)}.tag--crc .tag-value{background:var(--tag-crc-bg);border-color:#ef44444d;color:var(--tag-crc)}.length{font-family:var(--font-mono);color:var(--text-muted);text-align:center}.value{font-family:var(--font-mono);font-size:.9rem;color:var(--text-default);word-break:break-word}.description{color:var(--text-default);font-size:.9rem;line-height:1.45}.value--with-copy{display:flex;align-items:center;gap:.5rem}.field-copy-btn{width:22px;height:22px;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--text-muted);cursor:pointer;display:grid;place-items:center;opacity:0;transition:all .2s ease}.field-copy-btn:hover{background:var(--color-surface-alt);color:var(--color-primary)}.subtag-count{margin-left:.35rem;font-size:.8rem;color:var(--text-muted);font-style:italic}.subtag-toggle{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;border:1px solid rgba(124,58,237,.3);background:#7c3aed1f;color:var(--color-accent);cursor:pointer;transition:transform .2s ease,background .2s ease}.subtag-toggle:hover{transform:translateY(-1px);background:#7c3aed2e}.subtag-table{background:var(--color-surface-alt);border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:.35rem;padding:.75rem 1rem 1rem}.subtag-header{display:grid;grid-template-columns:80px 80px 1fr 1.2fr;gap:1rem;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-weight:700;padding-bottom:.35rem;border-bottom:1px solid var(--color-border)}.subtag-row{display:grid;grid-template-columns:80px 80px 1fr 1.2fr;gap:1rem;align-items:start;font-size:.85rem;padding:.5rem 0}.subtag-cell--tag{font-family:var(--font-mono);color:var(--color-accent);padding:.2rem .4rem;border-radius:8px;background:#7c3aed26;text-align:center}.subtag-cell--length{font-family:var(--font-mono);color:var(--text-muted);text-align:center}.subtag-cell--value{font-family:var(--font-mono);color:var(--text-default);word-break:break-word}.subtag-cell--description{color:var(--text-muted);font-size:.85rem;line-height:1.4}.qr-generator{width:100%;max-width:980px;margin:0 auto;border-radius:24px;padding:clamp(1.25rem,2.4vw,1.75rem);display:flex;flex-direction:column;gap:1.25rem}.generator-header{display:flex;align-items:center;justify-content:space-between;gap:1.25rem;flex-wrap:wrap}.generator-header h2{margin:0;font-size:clamp(1.8rem,3vw,2.3rem);font-weight:800;letter-spacing:-.018em;color:var(--text-strong)}.generator-header p{margin:.25rem 0 0;color:var(--text-muted);font-size:.95rem;max-width:520px}.generator-content{display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));align-items:start}.generator-form{display:flex;flex-direction:column;gap:1.75rem}.form-section{display:flex;flex-direction:column;gap:1rem}.form-section h3{margin:0;font-size:var(--fs-lg);font-weight:700;color:var(--text-strong)}.form-group{display:flex;flex-direction:column;gap:.5rem;background:var(--color-surface-alt);border-radius:16px;border:1px solid var(--color-border);padding:1rem 1.25rem}.form-group label{font-weight:600;color:var(--text-default);font-size:var(--fs-base)}.form-input{border-radius:12px;border:1px solid var(--color-border);padding:.65rem .9rem;font-size:var(--fs-base);transition:border-color .2s ease,box-shadow .2s ease}.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb26}.field-hint{margin:0;font-size:var(--fs-md);color:var(--text-muted)}.payment-type-selector{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:.75rem}.payment-type-button{display:flex;align-items:center;justify-content:center;padding:1rem;border-radius:14px;border:2px solid var(--color-border);background:var(--color-surface-alt);color:var(--text-default);cursor:pointer;transition:all .25s ease;font-family:inherit}.payment-type-button:hover{border-color:var(--color-primary);background:var(--color-surface);transform:translateY(-1px);box-shadow:var(--shadow-md)}.payment-type-button.active{border-color:var(--color-primary);background:#2563eb14;box-shadow:0 0 0 3px #2563eb1f}.payment-type-content{display:flex;flex-direction:column;gap:.25rem;text-align:center}.payment-type-content strong{font-size:var(--fs-base);font-weight:700;color:var(--text-strong)}.payment-type-content span{font-size:var(--fs-sm);color:var(--text-muted)}.payment-type-button.active .payment-type-content strong{color:var(--color-primary)}.payment-type-button.active .payment-type-content span{color:var(--color-primary);opacity:.8}.payment-type-info{margin-top:.5rem}.info-box{background:#2563eb0f;border:1px solid rgba(37,99,235,.2);border-radius:12px;padding:1rem 1.25rem}.info-box strong{display:block;font-size:.9rem;font-weight:700;color:var(--color-primary);margin-bottom:.5rem}.info-box p{margin:0;font-size:.875rem;color:var(--text-default);line-height:1.5}.error-messages{display:flex;flex-direction:column;gap:.75rem}.error-message{margin-top:0;padding:.85rem 1rem;border-radius:14px;background:#ef444414;border:1px solid rgba(239,68,68,.25);color:var(--color-danger);font-weight:600}.form-actions{display:flex;flex-wrap:wrap;gap:.75rem}.qr-result{display:flex;flex-direction:column;gap:1.5rem;background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:20px;padding:1.75rem;box-shadow:var(--shadow-sm)}.qr-display{display:flex;flex-direction:column;gap:1rem;align-items:center;text-align:center;position:relative}.qr-image{width:100%;max-width:240px;border-radius:16px;border:1px solid var(--color-border);background:#fff;box-shadow:var(--shadow-sm)}.preview-badge{margin-top:.5rem;display:inline-flex;align-items:center;padding:.35rem .85rem;border-radius:999px;background:linear-gradient(135deg,#2563eb1a,#3b82f61a);border:1px solid rgba(37,99,235,.25);color:var(--color-primary);font-size:.8rem;font-weight:600;letter-spacing:.02em;text-transform:uppercase}.preview-hint{display:inline-flex;align-items:center;gap:.5rem;margin:.5rem 0 0;padding:.85rem 1.1rem;border-radius:12px;background:#3b82f614;border:1px solid rgba(37,99,235,.15);color:var(--text-muted);font-size:.9rem;line-height:1.5}.preview-hint .icon{flex-shrink:0;color:var(--color-primary)}.qr-actions{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}.qr-string{display:flex;flex-direction:column;gap:.5rem}.qr-string h4{margin:0;font-size:1rem;font-weight:700;color:var(--text-strong)}.qr-string-display{background:var(--color-surface);border:1px solid var(--color-border);border-radius:14px;padding:1rem;max-height:200px;overflow:auto;font-family:var(--font-mono);font-size:.9rem;line-height:1.5}.qr-placeholder{display:flex;flex-direction:column;gap:1rem;align-items:center;text-align:center;color:var(--text-muted);padding:2.5rem 1rem;border:2px dashed var(--color-border);border-radius:18px;background:var(--color-surface)}.generating-spinner{display:inline-flex;align-items:center;gap:.6rem;color:var(--color-primary);font-weight:600}.spinner{width:18px;height:18px;border-radius:50%;border:3px solid rgba(37,99,235,.2);border-top-color:var(--color-primary);animation:spin .75s linear infinite}.loading-spinner{display:flex;align-items:center;justify-content:center;min-height:200px;padding:3rem}.loading-spinner .spinner{width:32px;height:32px;border-width:3px;border-color:#2563eb26;border-top-color:var(--color-primary)}.history-count-badge-drawer{padding:.2rem .6rem;border-radius:999px;background:var(--color-primary);color:#fff;font-size:.75rem;font-weight:700}.drawer-close-btn:hover{background:var(--color-surface-alt);color:var(--color-danger);border-color:var(--color-danger)}.history-drawer-content{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:1rem}.history-search{margin-bottom:.8rem}.history-search-input{width:100%;border:1px solid var(--color-border);border-radius:10px;background:var(--color-surface);color:var(--text-default);padding:.5rem .7rem;font-size:var(--fs-base)}.clear-history-button{display:inline-flex;align-items:center;justify-content:center;gap:.6rem;border-radius:14px;border:1px solid var(--color-border);background:var(--color-surface);color:var(--text-muted);font-weight:600;font-size:.95rem;padding:.65rem 1.2rem;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,color .2s ease}.clear-history-button:hover{transform:translateY(-2px);color:var(--text-default);box-shadow:var(--shadow-md)}.history-count{font-size:.9rem;color:var(--text-muted);font-weight:600}.empty-history-search{border:1px dashed var(--color-border);border-radius:10px;padding:.9rem;color:var(--text-muted);text-align:center;font-size:var(--fs-base)}.history-list{display:flex;flex-direction:column;gap:.85rem}.history-item{border:1px solid var(--color-border);border-radius:16px;background:var(--color-surface-alt);box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease}.history-item:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.history-item-content{padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.65rem;cursor:pointer;overflow-wrap:break-word}.history-item-header{display:flex;align-items:center;gap:.85rem}.history-item-icon{width:36px;height:36px;border-radius:12px;background:var(--color-surface);color:var(--color-primary);display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(37,99,235,.2)}.history-item-title{flex:1;font-weight:600;color:var(--text-strong);word-wrap:break-word;width:10%}.history-item-rename-input{border:1px solid var(--color-border);border-radius:8px;padding:.3rem .55rem;font-size:var(--fs-sm);min-width:180px}.history-item-action-button{border:1px solid var(--color-border);background:var(--color-surface);color:var(--text-muted);border-radius:8px;padding:.25rem .55rem;font-size:var(--fs-sm);line-height:1.2;cursor:pointer}.delete-item-button{padding:.35rem;border-radius:10px;background:transparent;border:none;color:var(--text-muted);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .2s ease}.delete-item-button:hover{color:var(--color-danger);background:#ef44441f;transform:translateY(-1px)}.history-item-details{display:flex;flex-wrap:wrap;gap:.75rem;font-size:.85rem;color:var(--text-muted)}.history-item-time{font-weight:600}.history-item-ref{background:#7c3aed1f;color:var(--color-accent);border-radius:10px;padding:.25rem .55rem;font-weight:600}@media(max-width:520px){.history-drawer{width:100%}}@media(max-width:900px){.header-content{align-items:flex-start}.header-text p{display:none}}@media(max-width:768px){.header-content{flex-direction:column;align-items:stretch;gap:.7rem}.App-header{padding:.7rem .75rem}.header-controls{justify-content:space-between;align-items:center;width:100%}.view-button{padding:.42rem .65rem}.section-heading,.data-header,.generator-header{flex-direction:column;align-items:flex-start}}@media(max-width:720px){.table-header,.subtag-header{display:none}.table-row,.subtag-row{grid-template-columns:1fr;gap:.5rem}.tag,.length,.value,.description,.subtag-cell--tag,.subtag-cell--length,.subtag-cell--value,.subtag-cell--description{display:flex;align-items:center;gap:.5rem}.tag:before{content:"Tag";font-weight:600;color:var(--text-muted);font-family:var(--font-sans);min-width:72px}.length:before{content:"Length";font-weight:600;color:var(--text-muted);font-family:var(--font-sans);min-width:72px}.value:before{content:"Value";font-weight:600;color:var(--text-muted);font-family:var(--font-sans);min-width:72px}.description:before{content:"Description";font-weight:600;color:var(--text-muted);font-family:var(--font-sans);min-width:72px}.subtag-cell--tag:before{content:"Sub-tag";font-weight:600;color:var(--text-muted);font-family:var(--font-sans);min-width:72px}.subtag-cell--length:before{content:"Length";font-weight:600;color:var(--text-muted);font-family:var(--font-sans);min-width:72px}.subtag-cell--value:before{content:"Value";font-weight:600;color:var(--text-muted);font-family:var(--font-sans);min-width:72px}.subtag-cell--description:before{content:"Description";font-weight:600;color:var(--text-muted);font-family:var(--font-sans);min-width:72px}.history-overlay{padding:1.25rem}}@media(max-width:520px){.qr-scanner,.file-upload,.text-input{padding:1.35rem}.qr-generator,.qr-data-display,.scanner-section,.generator-section{border-radius:22px;padding:1.75rem}.history-menu{border-radius:22px}.scanner-meta{flex-direction:column;align-items:stretch}.scanner-meta-actions{justify-content:space-between}.camera-select{width:100%}}.qr-generator-modern{max-width:1200px;margin:0 auto;padding:2rem}.generator-header-modern{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.header-title h2{margin:0;font-size:var(--fs-xl);color:var(--text-strong);letter-spacing:-.02em}.header-title p{margin:.25rem 0 0;color:var(--text-muted);font-size:var(--fs-base)}.payment-type-tabs{display:flex;gap:1rem;margin-bottom:2rem}.payment-tab{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease;flex:1;text-align:left}.payment-tab:hover{background:var(--color-surface-alt);border-color:var(--color-border-strong);transform:translateY(-1px)}.payment-tab.active{background:#2563eb14;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb26}.tab-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--color-surface-alt);border-radius:10px;color:var(--text-muted)}.payment-tab.active .tab-icon{background:var(--color-primary);color:#fff}.tab-content strong{display:block;color:var(--text-strong);font-size:var(--fs-base);margin-bottom:.15rem}.tab-content span{color:var(--text-muted);font-size:var(--fs-sm)}.generator-main{display:grid;grid-template-columns:1fr 400px;gap:2rem;align-items:start}.generator-form-modern{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:1.5rem}.section-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:1px solid var(--color-border);padding-bottom:1rem}.section-tab{padding:.5rem 1rem;background:transparent;border:none;color:var(--text-muted);font-weight:600;cursor:pointer;border-radius:var(--radius-md);transition:all .2s ease}.section-tab:hover{color:var(--text-strong);background:var(--color-surface-alt)}.section-tab.active{color:var(--color-primary);background:#2563eb1a}.form-content{min-height:400px}.form-field{margin-bottom:1.25rem}.form-field label{display:flex;align-items:center;gap:.35rem;margin-bottom:.5rem;font-weight:600;color:var(--text-strong)}.field-required{color:var(--color-danger);font-size:var(--fs-sm)}.field-optional{color:var(--text-muted);font-size:var(--fs-sm);font-weight:500}.form-select,.form-input{width:100%;padding:.75rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface-alt);color:var(--text-strong);font-size:var(--fs-base);transition:all .2s ease}.form-select:focus,.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb26;background:var(--color-surface)}.input-with-prefix{display:flex;align-items:center;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface-alt);overflow:hidden}.input-prefix{padding:.75rem .75rem .75rem 1rem;color:var(--text-muted);font-weight:600;font-size:var(--fs-lg)}.input-with-prefix .form-input{border:none;border-radius:0;background:transparent}.dynamic-fields{animation:fadeIn .3s ease}.error-messages-modern{margin:1rem 0;padding:1rem;background:#ef444414;border:1px solid rgba(239,68,68,.25);border-radius:var(--radius-md)}.error-message-modern{display:flex;align-items:center;gap:.5rem;color:var(--color-danger);font-size:var(--fs-sm);font-weight:600}.btn-primary{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.5rem;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-weight:600;font-size:var(--fs-base);cursor:pointer;transition:all .2s ease}.btn-primary:hover:not(:disabled){background:var(--color-primary-strong);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.action-secondary{display:flex;gap:.75rem;justify-content:center}.btn-secondary,.btn-ghost{display:flex;align-items:center;gap:.4rem;padding:.6rem 1rem;border:1px solid var(--color-border);background:var(--color-surface);color:var(--text-muted);border-radius:var(--radius-md);font-weight:600;font-size:var(--fs-sm);cursor:pointer;transition:all .2s ease}.btn-secondary:hover{background:var(--color-surface-alt);border-color:var(--color-border-strong);color:var(--text-strong)}.btn-ghost{border-color:transparent;background:transparent}.btn-ghost:hover{background:#ef44441a;color:var(--color-danger)}.generator-preview-modern{position:sticky;top:2rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden}.preview-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:var(--color-surface-alt);border-bottom:1px solid var(--color-border)}.preview-header h3{margin:0;font-size:var(--fs-base);color:var(--text-strong)}.preview-badge-modern{padding:.25rem .6rem;background:var(--color-primary);color:#fff;font-size:var(--fs-xs);font-weight:700;text-transform:uppercase;letter-spacing:.05em;border-radius:20px}.preview-content{padding:1.5rem}.qr-display-modern{display:flex;justify-content:center;margin-bottom:1.5rem}.qr-image-modern{max-width:250px;border-radius:var(--radius-md);box-shadow:var(--shadow-lg)}.qr-details{margin-bottom:1rem;padding:1rem;background:var(--color-surface-alt);border-radius:var(--radius-md)}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--color-border)}.detail-row:last-child{border-bottom:none}.detail-label{color:var(--text-muted);font-size:var(--fs-sm);font-weight:500}.detail-value{color:var(--text-strong);font-weight:600;font-size:var(--fs-sm)}.detail-value.highlight{color:var(--color-primary);font-size:var(--fs-base)}.qr-string-modern{margin-bottom:1rem;padding:.75rem;background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow-x:auto}.qr-string-modern code{font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--text-muted);word-break:break-all}.preview-actions{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.btn-action{display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.6rem 1rem;background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--text-strong);font-weight:600;font-size:var(--fs-sm);cursor:pointer;transition:all .2s ease}.btn-action:disabled{opacity:.4;cursor:not-allowed}.preview-notice{display:flex;align-items:center;gap:.4rem;margin-top:1rem;padding:.75rem;background:#2563eb14;border:1px solid rgba(37,99,235,.2);border-radius:var(--radius-md);color:var(--color-primary);font-size:var(--fs-xs);font-weight:600}.preview-placeholder-modern{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;text-align:center}.preview-placeholder-modern p{margin:1rem 0 0;color:var(--text-muted);font-size:var(--fs-sm)}.generating-indicator{display:flex;align-items:center;gap:.5rem;margin-top:1rem;color:var(--text-muted);font-size:var(--fs-sm)}.spinner-small{width:14px;height:14px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1024px){.generator-main{grid-template-columns:1fr}.generator-preview-modern{position:static;order:-1}.qr-image-modern{max-width:200px}}@media(max-width:640px){.qr-generator-modern{padding:1rem}.payment-type-tabs{flex-direction:column}.form-row{grid-template-columns:1fr}.action-secondary{flex-direction:column}.preview-actions{grid-template-columns:1fr}}.scan-container{width:100%;max-width:980px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:none;padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.scan-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.card-icon.accent-scan{color:var(--color-accent);background:#7c3aed1f;border-color:#7c3aed40}.scan-methods-container{display:flex;flex-direction:column;gap:1.5rem}.scan-method-tabs{display:flex;gap:1rem;margin-bottom:1rem}.scan-method-tab{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease;flex:1;text-align:left}.scan-method-tab:hover{background:var(--color-surface-alt);border-color:var(--color-border-strong);transform:translateY(-1px)}.scan-method-tab.active{background:#7c3aed14;border-color:var(--color-accent);box-shadow:0 0 0 3px #7c3aed26}.scan-method-tab .tab-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--color-surface-alt);border-radius:10px;color:var(--text-muted)}.scan-method-tab.active .tab-icon{background:var(--color-accent);color:#fff}.scan-method-tab .tab-content strong{display:block;color:var(--text-strong);font-size:var(--fs-base);margin-bottom:.15rem}.qr-scanner{background:linear-gradient(145deg,var(--color-surface) 0%,var(--color-surface-alt) 100%);border:1px solid var(--color-border);border-radius:var(--radius-2xl);padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem;box-shadow:0 4px 6px -1px #0f172a0d,0 10px 20px -3px #0f172a14,inset 0 1px #fff9;position:relative;overflow:hidden}.qr-scanner:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 20%,rgba(37,99,235,.03) 0%,transparent 50%),radial-gradient(circle at 70% 80%,rgba(124,58,237,.03) 0%,transparent 50%);animation:gradientShift 15s ease-in-out infinite;pointer-events:none}.qr-scanner .card-icon.accent-camera{width:52px;height:52px;border-radius:var(--radius-lg);background:linear-gradient(135deg,#2563eb26,#7c3aed26);border:1px solid rgba(37,99,235,.25);box-shadow:0 4px 12px #2563eb26,inset 0 1px #ffffff4d;transition:all .3s ease}.qr-scanner:hover .card-icon.accent-camera{transform:scale(1.05);box-shadow:0 6px 20px #2563eb33,inset 0 1px #ffffff4d}.camera-select select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb1f}.status-pill--live{background:linear-gradient(135deg,#0f9d581f,#0f9d5814);border-color:#0f9d584d;color:var(--color-success);animation:pulseLive 2s ease-in-out infinite}@keyframes pulseLive{0%,to{box-shadow:0 0 #0f9d5866}50%{box-shadow:0 0 0 8px #0f9d5800}}.status-pill--live:before{animation:pulseDot 1.5s ease-in-out infinite}@keyframes pulseDot{0%,to{transform:scale(1);opacity:1}50%{transform:scale(.8);opacity:.7}}.status-pill--attention{background:linear-gradient(135deg,#ef44441f,#ef444414);border-color:#ef44444d;color:var(--color-danger)}.status-pill--starting{background:linear-gradient(135deg,#2563eb1f,#2563eb14);border-color:#2563eb4d;color:var(--color-primary)}.scan-button{display:inline-flex;align-items:center;justify-content:center;gap:.6rem;padding:.85rem 1.75rem;border-radius:var(--radius-lg);border:none;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-strong) 100%);color:#fff;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #2563eb4d,0 2px 4px #2563eb33;position:relative;overflow:hidden}.scan-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #2563eb59,0 4px 8px #2563eb40}.scan-button:active:not(:disabled){transform:translateY(0)}.stop-button:disabled{opacity:.6;cursor:not-allowed}.qr-reader-frame--active{border-style:solid;border-color:var(--color-primary);box-shadow:0 0 0 4px #2563eb1a,0 12px 40px #2563eb26}.qr-reader-frame--active .corner-tl,.qr-reader-frame--active .corner-br{display:none}.scanner-placeholder-icon{width:80px;height:80px;border-radius:var(--radius-xl);background:linear-gradient(135deg,#2563eb14,#7c3aed14);border:1px solid rgba(37,99,235,.15);display:grid;place-items:center;margin-bottom:.5rem}.scanner-corner{position:absolute;width:40px;height:40px;pointer-events:none}.scanner-corner--tl{top:12px;left:12px;border-top:4px solid var(--color-primary);border-left:4px solid var(--color-primary);border-top-left-radius:12px}.scanner-corner--tr{top:12px;right:12px;border-top:4px solid var(--color-primary);border-right:4px solid var(--color-primary);border-top-right-radius:12px}.scanner-corner--bl{bottom:12px;left:12px;border-bottom:4px solid var(--color-primary);border-left:4px solid var(--color-primary);border-bottom-left-radius:12px}.scanner-corner--br{bottom:12px;right:12px;border-bottom:4px solid var(--color-primary);border-right:4px solid var(--color-primary);border-bottom-right-radius:12px}@media(max-width:640px){.qr-scanner{padding:1.25rem;gap:1rem}.qr-scanner .card-header{flex-direction:column;text-align:center;align-items:center}.scanner-meta{flex-direction:column;align-items:stretch}.scanner-meta-actions{justify-content:space-between}.qr-reader-frame{min-height:280px}.scan-button,.stop-button{width:100%;padding:1rem 1.5rem}}.qr-reader video{border-radius:var(--radius-xl);object-fit:cover}.file-upload:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#f59e0b,#d97706,#f59e0b);background-size:200% 100%;animation:shimmer 3s ease-in-out infinite}@keyframes shimmer{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.file-upload .card-icon.accent-upload{width:52px;height:52px;border-radius:var(--radius-lg);background:linear-gradient(135deg,#f59e0b26,#d9770626);border:1px solid rgba(245,158,11,.3);box-shadow:0 4px 12px #f59e0b26,inset 0 1px #ffffff4d;transition:all .3s ease}.file-upload:hover .card-icon.accent-upload{transform:scale(1.05) rotate(-5deg);box-shadow:0 6px 20px #f59e0b33,inset 0 1px #ffffff4d}.upload-dropzone{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:2.5rem 1.5rem;border-radius:var(--radius-xl);border:2px dashed rgba(245,158,11,.4);background:linear-gradient(145deg,#f59e0b0d,#d9770608);color:var(--text-default);cursor:pointer;transition:all .3s ease;position:relative;z-index:1;overflow:hidden}.upload-dropzone:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at center,rgba(245,158,11,.1) 0%,transparent 70%);opacity:0;transition:opacity .3s ease}.upload-dropzone:hover{transform:translateY(-3px);border-color:#f59e0bb3;background:linear-gradient(145deg,#f59e0b1a,#d977060d);box-shadow:0 8px 30px #f59e0b26}.upload-dropzone:hover:before{opacity:1}.upload-dropzone:active{transform:translateY(-1px)}.upload-dropzone-icon{width:72px;height:72px;border-radius:var(--radius-xl);background:linear-gradient(135deg,#f59e0b1f,#d9770614);border:1px solid rgba(245,158,11,.2);display:grid;place-items:center;transition:all .3s ease}.upload-dropzone:hover .upload-dropzone-icon{transform:scale(1.1) translateY(-2px);box-shadow:0 8px 24px #f59e0b33}.upload-dropzone-icon svg{width:36px;height:36px;color:#d97706;transition:transform .3s ease}.upload-dropzone:hover .upload-dropzone-icon svg{animation:bounceUp .6s ease}@keyframes bounceUp{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.dropzone-content{display:flex;flex-direction:column;align-items:center;gap:.5rem}.dropzone-title{font-size:1.1rem;font-weight:700;color:var(--text-strong)}.dropzone-subtitle{font-size:.875rem;color:var(--text-muted);font-weight:500}.dropzone-hint{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .85rem;background:#f59e0b1a;border:1px solid rgba(245,158,11,.2);border-radius:999px;font-size:.75rem;color:#d97706;font-weight:600;margin-top:.5rem}.upload-dropzone.drag-active{border-color:var(--color-success);background:linear-gradient(145deg,#0f9d581a,#0f9d580d)}.upload-dropzone.drag-active .upload-dropzone-icon{background:linear-gradient(135deg,#0f9d5826,#0f9d581a);border-color:#0f9d584d}.text-input:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--color-success),#10b981,var(--color-success));background-size:200% 100%;animation:shimmer 3s ease-in-out infinite}.text-input .card-icon.accent-text{width:52px;height:52px;border-radius:var(--radius-lg);background:linear-gradient(135deg,#0f9d5826,#10b9811a);border:1px solid rgba(15,157,88,.3);box-shadow:0 4px 12px #0f9d5826,inset 0 1px #ffffff4d;transition:all .3s ease}.text-input:hover .card-icon.accent-text{transform:scale(1.05);box-shadow:0 6px 20px #0f9d5833,inset 0 1px #ffffff4d}.qr-textarea-wrapper{position:relative;z-index:1;display:flex;flex-direction:column;flex:1;min-height:200px}.qr-textarea{width:100%;min-height:200px;padding:1rem 1.25rem;border-radius:var(--radius-lg);border:1px solid var(--color-border);background:var(--color-surface);font-family:var(--font-mono);font-size:.9rem;line-height:1.6;resize:vertical;transition:all .2s ease;color:var(--text-default);flex:1}.qr-textarea:focus{outline:none;border-color:var(--color-success);box-shadow:0 0 0 3px #0f9d581f}.qr-textarea::placeholder{color:#64748b99}.parse-button{display:inline-flex;align-items:center;justify-content:center;gap:.6rem;padding:.85rem 1.75rem;border-radius:var(--radius-lg);border:none;background:linear-gradient(135deg,var(--color-success) 0%,#059669 100%);color:#fff;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #0f9d584d,0 2px 4px #0f9d5833;position:relative;overflow:hidden}.parse-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #0f9d5859,0 4px 8px #0f9d5840}.input-hint{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:linear-gradient(135deg,#0f9d580f,#0f9d5808);border:1px solid rgba(15,157,88,.15);border-radius:var(--radius-md);font-size:.85rem;color:var(--text-muted);margin:0;position:relative;z-index:1}.input-hint svg{color:var(--color-accent);flex-shrink:0}.file-upload{background:linear-gradient(145deg,var(--color-surface) 0%,var(--color-surface-alt) 100%);border:1px solid var(--color-border);border-radius:var(--radius-2xl);padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem;box-shadow:0 4px 6px -1px #0f172a0d,0 10px 20px -3px #0f172a14,inset 0 1px #fff9;position:relative;overflow:hidden}.file-upload:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 20%,rgba(14,165,233,.04) 0%,transparent 50%),radial-gradient(circle at 70% 80%,rgba(99,102,241,.03) 0%,transparent 50%);animation:gradientShift 15s ease-in-out infinite;pointer-events:none}.file-upload .card-icon.accent-upload{width:52px;height:52px;border-radius:var(--radius-lg);background:linear-gradient(135deg,#f59e0b26,#d977061a);border:1px solid rgba(245,158,11,.25);box-shadow:0 4px 12px #f59e0b1f,inset 0 1px #ffffff4d;transition:all .3s ease}.file-upload:hover .card-icon.accent-upload{transform:scale(1.05);box-shadow:0 6px 20px #f59e0b2e,inset 0 1px #ffffff4d}.file-upload .card-icon.accent-upload svg{width:26px;height:26px;color:#d97706}.upload-dropzone{display:flex;flex-direction:column;align-items:center;gap:.875rem;padding:2.5rem 1.5rem;border-radius:var(--radius-xl);border:2px dashed rgba(245,158,11,.35);background:linear-gradient(145deg,#f59e0b0a,#d9770605);color:var(--text-default);cursor:pointer;transition:all .3s ease;position:relative;z-index:1}.upload-dropzone:hover:not(:disabled){transform:translateY(-3px);border-color:#f59e0b99;background:linear-gradient(145deg,#f59e0b14,#d977060a);box-shadow:0 8px 30px #f59e0b1f}.upload-dropzone:active:not(:disabled){transform:translateY(-1px)}.upload-dropzone-icon{width:72px;height:72px;border-radius:var(--radius-xl);background:linear-gradient(135deg,#f59e0b1a,#d977060f);border:1px solid rgba(245,158,11,.15);display:grid;place-items:center;transition:all .3s ease}.upload-dropzone:hover:not(:disabled) .upload-dropzone-icon{transform:scale(1.08);box-shadow:0 8px 24px #f59e0b26}.upload-dropzone-icon svg{width:36px;height:36px;color:#d97706}.dropzone-hint{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .75rem;background:#f59e0b14;border:1px solid rgba(245,158,11,.15);border-radius:999px;font-size:.75rem;color:#d97706;font-weight:600;margin-top:.35rem}.upload-dropzone.drag-active{border-color:#0f9d5880;background:linear-gradient(145deg,#0f9d580f,#0f9d5808)}.upload-dropzone.drag-active .upload-dropzone-icon{background:linear-gradient(135deg,#0f9d581a,#0f9d580f);border-color:#0f9d5833}.text-input{background:linear-gradient(145deg,var(--color-surface) 0%,var(--color-surface-alt) 100%);border:1px solid var(--color-border);border-radius:var(--radius-2xl);padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem;box-shadow:0 4px 6px -1px #0f172a0d,0 10px 20px -3px #0f172a14,inset 0 1px #fff9;position:relative;overflow:hidden}.text-input:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 20%,rgba(15,157,88,.04) 0%,transparent 50%),radial-gradient(circle at 70% 80%,rgba(16,185,129,.03) 0%,transparent 50%);animation:gradientShift 15s ease-in-out infinite;pointer-events:none}.text-input .card-icon.accent-text{width:52px;height:52px;border-radius:var(--radius-lg);background:linear-gradient(135deg,#0f9d5826,#10b9811a);border:1px solid rgba(15,157,88,.25);box-shadow:0 4px 12px #0f9d581f,inset 0 1px #ffffff4d;transition:all .3s ease}.text-input:hover .card-icon.accent-text{transform:scale(1.05);box-shadow:0 6px 20px #0f9d582e,inset 0 1px #ffffff4d}.text-input .card-icon.accent-text svg{width:26px;height:26px;color:var(--color-success)}.qr-textarea:focus{outline:none;border-color:var(--color-success);box-shadow:0 0 0 3px #0f9d581a}.qr-textarea::placeholder{color:#64748b80}.parse-button{display:inline-flex;align-items:center;justify-content:center;gap:.6rem;padding:.85rem 1.75rem;border-radius:var(--radius-lg);border:none;background:linear-gradient(135deg,var(--color-success) 0%,#059669 100%);color:#fff;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #0f9d5847,0 2px 4px #0f9d5833;position:relative;overflow:hidden}.parse-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #0f9d5852,0 4px 8px #0f9d5838}.parse-button:active:not(:disabled){transform:translateY(0)}.clear-input-button:disabled{opacity:.6;cursor:not-allowed}@media(max-width:640px){.file-upload,.text-input{padding:1.25rem;gap:1rem}.file-upload .card-header,.text-input .card-header{flex-direction:column;text-align:center;align-items:center}.upload-dropzone{padding:2rem 1rem}.upload-dropzone-icon{width:64px;height:64px}.upload-dropzone-icon svg{width:32px;height:32px}.qr-textarea{min-height:120px;padding:.875rem 1rem}.input-controls{flex-direction:column}.parse-button,.clear-input-button{width:100%;padding:1rem 1.5rem}}.App{min-height:100vh;display:flex;flex-direction:column}.App-header{position:sticky;top:0;z-index:100;background:#ffffffd9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--color-border);padding:.875rem 1.25rem}.header-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:1.5rem}.header-brand{display:flex;align-items:center;gap:.875rem;flex-shrink:0}.brand-icon{width:40px;height:40px;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-accent) 100%);color:#fff;display:grid;place-items:center;box-shadow:0 4px 14px #0ea5e959}.brand-icon svg{width:22px;height:22px}.header-brand h1{margin:0;font-size:var(--fs-xl);font-weight:700;color:var(--text-strong);letter-spacing:-.02em}.main-nav{display:flex;align-items:center;gap:.25rem;padding:.25rem;background:var(--color-surface-muted);border-radius:var(--radius-lg);border:1px solid var(--color-border)}.nav-tab{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;border-radius:var(--radius-md);border:none;background:transparent;color:var(--text-muted);font-weight:600;font-size:var(--fs-sm);cursor:pointer;transition:all .2s ease}.nav-tab:hover{color:var(--text-default);background:#fff9}.nav-tab.active{background:var(--color-surface);color:var(--color-primary);box-shadow:var(--shadow-sm)}.nav-tab svg{width:18px;height:18px}.history-toggle-button{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);color:var(--text-muted);cursor:pointer;transition:all .2s ease;position:relative;flex-shrink:0}.history-toggle-button:hover{color:var(--color-primary);background:var(--color-primary-muted);border-color:var(--color-primary-soft);transform:translateY(-1px)}.history-count-badge{position:absolute;top:-5px;right:-5px;min-width:20px;height:20px;border-radius:999px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-accent) 100%);color:#fff;font-size:.7rem;font-weight:700;display:grid;place-items:center;box-shadow:0 2px 8px #0ea5e966}.App-main{flex:1;padding:1.5rem;display:flex;justify-content:center}.scan-container{width:100%;max-width:900px}.scan-header{margin-bottom:1.5rem}.header-title{display:flex;align-items:center;gap:1rem}.header-title h2{margin:0;font-size:1.5rem;font-weight:800;color:var(--text-strong);letter-spacing:-.02em}.header-title p{margin:.25rem 0 0;color:var(--text-muted);font-size:var(--fs-md)}.card-icon{width:52px;height:52px;border-radius:var(--radius-lg);display:grid;place-items:center;background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);transition:all .3s ease}.card-icon.accent-scan{background:linear-gradient(135deg,#0ea5e926,#6366f11a);border-color:#0ea5e94d;color:var(--color-primary);box-shadow:0 4px 16px #0ea5e926}.card-icon.accent-scan svg{width:28px;height:28px}.scan-method-tab .tab-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--color-surface-alt);border-radius:var(--radius-md);color:var(--text-muted);transition:all .2s ease}.scan-method-tab .tab-content strong{display:block;color:var(--text-strong);font-size:var(--fs-base);font-weight:600;margin-bottom:.15rem}.scan-method-tab .tab-content span{color:var(--text-muted);font-size:var(--fs-sm)}.scan-method-content{padding:1.5rem;min-height:400px}.scan-loading{display:flex;align-items:center;justify-content:center;gap:.75rem;min-height:300px;color:var(--text-muted)}.error-messages-modern{display:flex;flex-direction:column;gap:.75rem}.error-message-modern{display:inline-flex;align-items:center;gap:.75rem;padding:.875rem 1rem;border-radius:var(--radius-lg);background:linear-gradient(135deg,#ef444414,#ef44440a);border:1px solid rgba(239,68,68,.2);color:var(--color-danger);font-weight:500;font-size:var(--fs-sm)}.generator-section{width:100%;max-width:1200px}.generator-main{display:grid;grid-template-columns:1fr 380px;gap:1.5rem;align-items:start}@media(max-width:900px){.generator-main{grid-template-columns:1fr}}.generator-form-modern{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-2xl);padding:1.5rem;box-shadow:var(--shadow-sm)}.generator-form-modern .form-content h3{font-size:var(--fs-lg);font-weight:700;color:var(--text-strong);margin-bottom:1.25rem;letter-spacing:-.01em}.form-sections{display:flex;flex-direction:column;gap:1rem}.form-field{display:flex;flex-direction:column;gap:.5rem}.form-field label{display:flex;align-items:center;gap:.35rem;font-weight:600;color:var(--text-default);font-size:var(--fs-sm)}.field-label{color:var(--text-default)}.field-required{color:var(--color-danger)}.field-optional{color:var(--text-muted);font-weight:500;font-size:var(--fs-xs)}.form-input,.form-select{width:100%;padding:.75rem 1rem;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);color:var(--text-default);font-size:var(--fs-base);transition:all .2s ease}.form-input:hover,.form-select:hover{border-color:var(--color-border-strong)}.form-input:focus,.form-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0ea5e926}.form-input::placeholder{color:var(--text-placeholder)}.field-hint{font-size:var(--fs-xs);color:var(--text-muted);margin-top:.25rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media(max-width:640px){.form-row{grid-template-columns:1fr}}.form-actions-modern{display:flex;flex-direction:column;gap:1rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--color-border)}.action-secondary{display:flex;gap:.75rem;flex-wrap:wrap}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.5rem;border-radius:var(--radius-lg);border:none;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-accent) 100%);color:#fff;font-weight:600;font-size:var(--fs-base);cursor:pointer;transition:all .3s ease;box-shadow:0 4px 14px #0ea5e959;position:relative;overflow:hidden}.btn-primary:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #0ea5e973}.btn-primary:hover:not(:disabled):before{left:100%}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);color:var(--text-muted);font-weight:500;font-size:var(--fs-sm);cursor:pointer;transition:all .2s ease}.btn-secondary:hover{background:var(--color-surface-muted);border-color:var(--color-border-strong);color:var(--text-default)}.qr-image-modern{width:100%;max-width:220px;border-radius:var(--radius-md);box-shadow:var(--shadow-md)}.btn-action{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);color:var(--text-default);font-weight:500;font-size:var(--fs-sm);cursor:pointer;transition:all .2s ease}.btn-action:disabled{opacity:.5;cursor:not-allowed}.preview-placeholder-modern{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:3rem 1.5rem;text-align:center;color:var(--text-muted)}.drawer-backdrop{position:fixed;inset:0;background:#0f172a00;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px);z-index:1000;pointer-events:none;transition:all .3s ease}.drawer-backdrop.is-open{background:#0f172a66;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:auto}.history-drawer{position:fixed;top:0;right:0;width:var(--drawer-width);max-width:100%;height:100vh;background:var(--color-surface);border-left:1px solid var(--color-border);box-shadow:-10px 0 40px #0f172a26;z-index:1001;display:flex;flex-direction:column;transform:translate(100%);transition:transform .3s cubic-bezier(.16,1,.3,1)}.history-drawer.is-open{transform:translate(0)}.history-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem;border-bottom:1px solid var(--color-border);flex-shrink:0}.history-drawer-title{display:flex;align-items:center;gap:.75rem}.history-drawer-title h2{margin:0;font-size:var(--fs-xl);font-weight:700;color:var(--text-strong)}.history-count-badge-drawer{padding:.25rem .6rem;border-radius:999px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-accent) 100%);color:#fff;font-size:.75rem;font-weight:700}.drawer-close-btn{width:36px;height:36px;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);color:var(--text-muted);cursor:pointer;display:grid;place-items:center;transition:all .2s ease}.drawer-close-btn:hover{background:var(--color-surface-alt);color:var(--color-danger);border-color:var(--color-danger-light)}.history-drawer-content{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.875rem}.history-search{margin-bottom:.5rem}.history-search-input{width:100%;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--text-default);padding:.625rem .875rem;font-size:var(--fs-base);transition:all .2s ease}.history-search-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0ea5e91a}.history-actions{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.clear-history-button{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);color:var(--text-muted);font-weight:500;font-size:var(--fs-sm);cursor:pointer;transition:all .2s ease}.clear-history-button:hover{background:var(--color-danger-light);border-color:var(--color-danger-soft);color:var(--color-danger)}.history-count{font-size:var(--fs-sm);color:var(--text-muted);font-weight:500}.empty-history{display:flex;flex-direction:column;align-items:center;gap:.75rem;color:var(--text-muted);padding:3rem 1rem;text-align:center}.empty-history-search{border:1px dashed var(--color-border);border-radius:var(--radius-md);padding:1rem;color:var(--text-muted);text-align:center;font-size:var(--fs-base)}.history-list{display:flex;flex-direction:column;gap:.75rem}.history-item{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface-alt);transition:all .2s ease}.history-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--color-primary-soft)}.history-item-content{padding:1rem;display:flex;flex-direction:column;gap:.5rem;cursor:pointer}.history-item-header{display:flex;align-items:center;gap:.75rem}.history-item-icon{width:36px;height:36px;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--color-primary-light) 0%,rgba(99,102,241,.1) 100%);color:var(--color-primary);display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--color-primary-soft);flex-shrink:0}.history-item-title{flex:1;font-weight:600;color:var(--text-strong);word-break:break-word;font-size:var(--fs-sm)}.history-item-rename{display:inline-flex;align-items:center;gap:.4rem;flex-wrap:wrap}.history-item-rename-input{border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:.35rem .625rem;font-size:var(--fs-sm);min-width:160px;background:var(--color-surface);color:var(--text-default)}.history-item-rename-input:focus{outline:none;border-color:var(--color-primary)}.history-item-action-button{border:1px solid var(--color-border);background:var(--color-surface);color:var(--text-muted);border-radius:var(--radius-sm);padding:.35rem .625rem;font-size:var(--fs-xs);line-height:1.2;cursor:pointer;transition:all .2s ease}.history-item-action-button:hover{color:var(--text-default);border-color:var(--color-border-strong)}.delete-item-button{padding:.35rem;border-radius:var(--radius-sm);background:transparent;border:none;color:var(--text-muted);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.delete-item-button:hover{color:var(--color-danger);background:var(--color-danger-light)}.history-item-details{display:flex;flex-wrap:wrap;gap:.5rem;font-size:var(--fs-xs);color:var(--text-muted)}.history-item-time{font-weight:500}.history-item-ref{background:var(--color-accent-light);color:var(--color-accent);border-radius:var(--radius-sm);padding:.2rem .5rem;font-weight:600}@media(max-width:900px){.header-content{flex-wrap:wrap}.main-nav{order:3;width:100%;justify-content:center}}@media(max-width:768px){.App-header{padding:.75rem 1rem}.header-content{flex-direction:column;align-items:stretch;gap:.75rem}.main-nav{order:0}.history-toggle-button{position:absolute;top:.75rem;right:1rem}.App-main{padding:1rem}.generator-form-modern{padding:1.25rem}.generator-preview-modern{position:static}.history-drawer{width:100%}}@media(max-width:640px){.scan-method-tabs{flex-direction:column}.scan-method-tab{padding:.75rem}.scan-method-tab .tab-content span{display:none}.form-actions-modern{flex-direction:column}.action-secondary{justify-content:center}.preview-actions{flex-direction:column}}.qr-scanner{background:linear-gradient(145deg,var(--color-surface) 0%,var(--color-surface-alt) 100%);border:1px solid var(--color-border);border-radius:var(--radius-2xl);padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}.qr-scanner .card-header{display:flex;align-items:flex-start;gap:1rem;position:relative;z-index:1}.qr-scanner .card-icon.accent-camera{width:52px;height:52px;border-radius:var(--radius-lg);background:linear-gradient(135deg,#0ea5e926,#6366f11a);border:1px solid rgba(14,165,233,.25);box-shadow:0 4px 12px #0ea5e926;transition:all .3s ease}.scanner-meta{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;position:relative;z-index:1;padding:.75rem;background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border)}.inline-error{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;border-radius:var(--radius-lg);background:linear-gradient(135deg,#ef444414,#ef44440a);border:1px solid rgba(239,68,68,.2);color:var(--color-danger);font-weight:500;font-size:.9rem;position:relative;z-index:1}.scanner-controls{display:flex;justify-content:center;position:relative;z-index:1}.qr-reader-frame{width:100%;max-width:480px;margin:0 auto;border-radius:var(--radius-xl);overflow:hidden;background:var(--color-surface);border:2px dashed var(--color-border);min-height:320px;display:flex;align-items:center;justify-content:center;transition:all .4s ease;position:relative;z-index:1}.scanner-placeholder-icon{width:80px;height:80px;border-radius:var(--radius-xl);background:linear-gradient(135deg,#0ea5e914,#6366f10f);border:1px solid rgba(14,165,233,.15);display:grid;place-items:center;margin-bottom:.5rem}.scanner-placeholder-icon svg{width:40px;height:40px;color:var(--color-primary);opacity:.6}.scanner-placeholder p{margin:0;font-size:.95rem;max-width:260px;line-height:1.6}.scan-status{text-align:center;font-size:.875rem;color:var(--text-muted);font-weight:500;position:relative;z-index:1;padding:.75rem;background:var(--color-surface-alt);border-radius:var(--radius-md);border:1px solid var(--color-border)}.file-upload{background:linear-gradient(145deg,var(--color-surface) 0%,var(--color-surface-alt) 100%);border:1px solid var(--color-border);border-radius:var(--radius-2xl);padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;min-height:480px}.file-upload:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 20%,rgba(245,158,11,.04) 0%,transparent 50%),radial-gradient(circle at 70% 80%,rgba(217,119,6,.03) 0%,transparent 50%);animation:gradientShift 15s ease-in-out infinite;pointer-events:none}.file-upload .card-header{display:flex;align-items:flex-start;gap:1rem;position:relative;z-index:1}.file-upload .card-icon.accent-upload{width:52px;height:52px;border-radius:var(--radius-lg);background:linear-gradient(135deg,#0ea5e926,#6366f11a);border:1px solid rgba(14,165,233,.25);box-shadow:0 4px 12px #0ea5e91f;transition:all .3s ease}.file-upload:hover .card-icon.accent-upload{transform:scale(1.05);box-shadow:0 6px 20px #0ea5e92e}.file-upload .card-icon.accent-upload svg{width:26px;height:26px;color:var(--color-primary)}.file-upload .card-title{font-size:1.15rem;font-weight:700;color:var(--text-strong);letter-spacing:-.01em}.file-upload .card-subtitle{font-size:.875rem;color:var(--text-muted);line-height:1.5}.upload-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:3rem 1.5rem;border-radius:var(--radius-xl);border:2px dashed rgba(14,165,233,.4);background:linear-gradient(145deg,#0ea5e90f,#6366f108);color:var(--text-default);cursor:pointer;transition:all .3s ease;position:relative;z-index:1;flex:1;min-height:320px}.upload-dropzone:hover:not(:disabled){transform:translateY(-3px);border-color:#0ea5e9b3;background:linear-gradient(145deg,#0ea5e91a,#6366f10d);box-shadow:0 8px 30px #0ea5e926}.upload-dropzone:disabled{opacity:.7;cursor:not-allowed}.upload-dropzone-icon{width:72px;height:72px;border-radius:var(--radius-xl);background:linear-gradient(135deg,#0ea5e91f,#6366f114);border:1px solid rgba(14,165,233,.2);display:grid;place-items:center;transition:all .3s ease}.upload-dropzone:hover:not(:disabled) .upload-dropzone-icon{transform:scale(1.08);box-shadow:0 8px 24px #0ea5e933}.upload-dropzone-icon svg{width:36px;height:36px;color:var(--color-primary)}.dropzone-content{display:flex;flex-direction:column;align-items:center;gap:.35rem}.dropzone-title{font-size:1.05rem;font-weight:600;color:var(--text-strong)}.dropzone-subtitle{font-size:.85rem;color:var(--text-muted);font-weight:500}.dropzone-hint{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .85rem;background:linear-gradient(135deg,#0ea5e91a,#6366f114);border:1px solid rgba(14,165,233,.2);border-radius:999px;font-size:.75rem;color:var(--color-primary-strong);font-weight:600;margin-top:.35rem}.upload-dropzone.drag-active{border-color:var(--color-success);background:linear-gradient(145deg,#10b9810f,#10b98108)}.upload-dropzone.drag-active .upload-dropzone-icon{background:linear-gradient(135deg,#10b9811a,#10b9810f);border-color:#10b98133}.upload-dropzone.drag-active .upload-dropzone-icon svg{color:var(--color-success)}.text-input{background:linear-gradient(145deg,var(--color-surface) 0%,var(--color-surface-alt) 100%);border:1px solid var(--color-border);border-radius:var(--radius-2xl);padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;min-height:480px}.text-input:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 20%,rgba(99,102,241,.04) 0%,transparent 50%),radial-gradient(circle at 70% 80%,rgba(14,165,233,.03) 0%,transparent 50%);animation:gradientShift 15s ease-in-out infinite;pointer-events:none}.text-input .card-header{display:flex;align-items:flex-start;gap:1rem;position:relative;z-index:1}.text-input .card-icon.accent-text{width:52px;height:52px;border-radius:var(--radius-lg);background:linear-gradient(135deg,#6366f126,#0ea5e91a);border:1px solid rgba(99,102,241,.25);box-shadow:0 4px 12px #6366f11f;transition:all .3s ease}.text-input:hover .card-icon.accent-text{transform:scale(1.05);box-shadow:0 6px 20px #6366f12e}.text-input .card-icon.accent-text svg{width:26px;height:26px;color:var(--color-accent)}.text-input .card-title{font-size:1.15rem;font-weight:700;color:var(--text-strong);letter-spacing:-.01em}.text-input .card-subtitle{font-size:.875rem;color:var(--text-muted);line-height:1.5}.qr-textarea-wrapper{position:relative;z-index:1}.qr-textarea{width:100%;min-height:140px;padding:1rem 1.25rem;border-radius:var(--radius-lg);border:1px solid var(--color-border);background:var(--color-surface);font-family:var(--font-mono);font-size:.9rem;line-height:1.6;resize:vertical;transition:all .2s ease;color:var(--text-default)}.qr-textarea:hover{border-color:var(--color-border-strong)}.qr-textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #6366f11f}.qr-textarea::placeholder{color:var(--text-placeholder)}.qr-textarea:disabled{background:var(--color-surface-muted);cursor:not-allowed}.char-counter{position:absolute;bottom:.75rem;right:.75rem;font-size:.75rem;color:var(--text-muted);font-weight:500;padding:.25rem .5rem;background:var(--color-surface-alt);border-radius:var(--radius-sm);border:1px solid var(--color-border)}.input-controls{display:flex;flex-wrap:wrap;gap:.75rem;position:relative;z-index:1}.parse-button{display:inline-flex;align-items:center;justify-content:center;gap:.6rem;padding:.85rem 1.75rem;border-radius:var(--radius-lg);border:none;background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-primary) 100%);color:#fff;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 14px #6366f159;position:relative;overflow:hidden}.parse-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.parse-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #6366f173}.parse-button:hover:not(:disabled):before{left:100%}.parse-button:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.clear-input-button{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.85rem 1.25rem;border-radius:var(--radius-lg);border:1px solid var(--color-border);background:var(--color-surface-alt);color:var(--text-muted);font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s ease}.clear-input-button:hover:not(:disabled){background:var(--color-surface);border-color:var(--color-border-strong);color:var(--text-default);transform:translateY(-2px);box-shadow:var(--shadow-md)}.input-hint{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.85rem;color:var(--text-muted);margin:0;position:relative;z-index:1}.input-hint svg{color:var(--color-success);flex-shrink:0}.kbd-shortcut{display:inline-flex;align-items:center;gap:.2rem;padding:.2rem .5rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:6px;font-family:var(--font-mono);font-size:.75rem;font-weight:600;color:var(--text-default);box-shadow:0 1px 2px #0f172a0d}@media(max-width:640px){.qr-scanner,.file-upload,.text-input{padding:1.25rem;gap:1rem}.qr-scanner .card-header,.file-upload .card-header,.text-input .card-header{flex-direction:column;text-align:center;align-items:center}.scanner-meta{flex-direction:column;align-items:stretch}.qr-reader-frame{min-height:280px}.upload-dropzone{padding:2rem 1rem}.qr-textarea{min-height:120px}.input-controls{flex-direction:column}.scan-button,.stop-button,.parse-button,.clear-input-button{width:100%;padding:1rem 1.5rem}}.scan-methods-container{display:flex;flex-direction:column;gap:1rem}.scan-method-tabs{display:flex;gap:.5rem;padding:.5rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm)}.scan-method-tab{display:flex;align-items:center;gap:.75rem;flex:1;padding:.875rem 1rem;border-radius:var(--radius-lg);border:1px solid transparent;background:transparent;color:var(--text-muted);cursor:pointer;transition:all .2s ease;text-align:left}.scan-method-tab:hover{background:var(--color-surface-muted);color:var(--text-default)}.scan-method-tab.active{background:linear-gradient(135deg,var(--color-primary-muted) 0%,rgba(99,102,241,.05) 100%);border-color:var(--color-primary-soft);color:var(--color-primary)}.scan-method-tab .tab-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--color-surface-alt);border-radius:var(--radius-md);color:var(--text-muted);transition:all .2s ease;flex-shrink:0}.scan-method-tab.active .tab-icon{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-accent) 100%);color:#fff;box-shadow:0 4px 12px #0ea5e94d}.scan-method-tab .tab-content{display:flex;flex-direction:column;min-width:0}.scan-method-tab .tab-content strong{display:block;color:var(--text-strong);font-size:var(--fs-base);font-weight:600;margin-bottom:.15rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.scan-method-tab .tab-content span{color:var(--text-muted);font-size:var(--fs-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.scan-method-tab.active .tab-content strong{color:var(--color-primary)}.scan-method-content{padding:1.5rem;min-height:520px;position:relative}.scan-method-content>*{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.scan-loading{display:flex;align-items:center;justify-content:center;gap:.75rem;min-height:400px;color:var(--text-muted)}.spinner-small{width:20px;height:20px;border-radius:50%;border:2px solid rgba(14,165,233,.2);border-top-color:var(--color-primary);animation:spin .75s linear infinite}@media(max-width:640px){.scan-method-tabs{flex-direction:column}.scan-method-tab{padding:.75rem}.scan-method-tab .tab-content span{display:none}.scan-method-content{min-height:480px;padding:1rem}}.qr-scanner{background:linear-gradient(145deg,var(--color-surface) 0%,var(--color-surface-alt) 100%);border:1px solid var(--color-border);border-radius:var(--radius-2xl);padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;min-height:480px}.qr-scanner:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 20%,rgba(14,165,233,.04) 0%,transparent 50%),radial-gradient(circle at 70% 80%,rgba(99,102,241,.03) 0%,transparent 50%);animation:gradientShift 15s ease-in-out infinite;pointer-events:none}@keyframes gradientShift{0%,to{transform:translate(0) rotate(0)}33%{transform:translate(2%,2%) rotate(5deg)}66%{transform:translate(-2%,1%) rotate(-5deg)}}.qr-scanner .card-header{display:flex;align-items:flex-start;gap:1rem;position:relative;z-index:1;flex-shrink:0}.qr-scanner .card-icon.accent-camera{width:52px;height:52px;border-radius:var(--radius-lg);background:linear-gradient(135deg,#0ea5e926,#6366f11a);border:1px solid rgba(14,165,233,.25);box-shadow:0 4px 12px #0ea5e926;transition:all .3s ease;flex-shrink:0}.qr-scanner:hover .card-icon.accent-camera{transform:scale(1.05);box-shadow:0 6px 20px #0ea5e933}.qr-scanner .card-icon.accent-camera svg{width:26px;height:26px;color:var(--color-primary)}.qr-scanner .card-title{font-size:1.15rem;font-weight:700;color:var(--text-strong);letter-spacing:-.01em}.qr-scanner .card-subtitle{font-size:.875rem;color:var(--text-muted);line-height:1.5}.scanner-meta{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;position:relative;z-index:1;padding:.75rem;background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);flex-shrink:0}.camera-select{display:flex;flex-direction:column;gap:.35rem;min-width:200px;flex:1}.camera-select span{font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;font-weight:700;color:var(--text-muted)}.camera-select select{border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface-alt);font-size:.9rem;padding:.5rem .75rem;color:var(--text-default);transition:all .2s ease;cursor:pointer}.camera-select select:hover{border-color:var(--color-border-strong)}.camera-select select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0ea5e91f}.camera-select select:disabled{background:var(--color-surface-muted);color:var(--text-muted);cursor:not-allowed}.scanner-meta-actions{display:flex;align-items:center;gap:.75rem}.camera-refresh-button{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface-alt);color:var(--text-muted);cursor:pointer;transition:all .2s ease}.camera-refresh-button:hover:not(:disabled){background:var(--color-surface);border-color:var(--color-primary);color:var(--color-primary);transform:rotate(180deg)}.camera-refresh-button:disabled{opacity:.5;cursor:not-allowed}.status-pill{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .9rem;border-radius:999px;border:1px solid var(--color-border);background:var(--color-surface-alt);color:var(--text-muted);font-weight:600;font-size:.8rem;transition:all .3s ease}.status-pill:before{content:"";width:8px;height:8px;border-radius:50%;background:currentColor;transition:all .3s ease}.status-pill--live{background:linear-gradient(135deg,#10b9811a,#10b9810d);border-color:#10b9814d;color:var(--color-success);animation:pulseLive 2s ease-in-out infinite}@keyframes pulseLive{0%,to{box-shadow:0 0 #10b98166}50%{box-shadow:0 0 0 8px #10b98100}}.status-pill--attention{background:linear-gradient(135deg,#ef44441a,#ef44440d);border-color:#ef44444d;color:var(--color-danger)}.status-pill--starting{background:linear-gradient(135deg,#0ea5e91a,#0ea5e90d);border-color:#0ea5e94d;color:var(--color-primary)}.status-pill--starting:before{animation:spin 1s linear infinite;border-radius:50%;border:2px solid currentColor;border-top-color:transparent;width:8px;height:8px;background:transparent}.inline-error{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;border-radius:var(--radius-lg);background:linear-gradient(135deg,#ef444414,#ef44440a);border:1px solid rgba(239,68,68,.2);color:var(--color-danger);font-weight:500;font-size:.9rem;position:relative;z-index:1;flex-shrink:0}.scanner-controls{display:flex;justify-content:center;position:relative;z-index:1;flex-shrink:0}.scan-button{display:inline-flex;align-items:center;justify-content:center;gap:.6rem;padding:.85rem 1.75rem;border-radius:var(--radius-lg);border:none;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-accent) 100%);color:#fff;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 14px #0ea5e959;position:relative;overflow:hidden}.scan-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.scan-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #0ea5e973}.scan-button:hover:not(:disabled):before{left:100%}.scan-button:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.stop-button{display:inline-flex;align-items:center;justify-content:center;gap:.6rem;padding:.85rem 1.75rem;border-radius:var(--radius-lg);border:1px solid rgba(239,68,68,.3);background:linear-gradient(135deg,#ef44441a,#ef44440d);color:var(--color-danger);font-weight:600;font-size:.95rem;cursor:pointer;transition:all .3s ease}.stop-button:hover:not(:disabled){background:linear-gradient(135deg,#ef444426,#ef44441a);border-color:#ef444466;transform:translateY(-2px);box-shadow:0 4px 12px #ef444433}.qr-reader-frame{width:100%;max-width:400px;margin:0 auto;border-radius:var(--radius-xl);overflow:hidden;background:var(--color-surface);border:2px dashed var(--color-border);min-height:280px;display:flex;align-items:center;justify-content:center;transition:all .4s ease;position:relative;z-index:1;flex-shrink:0}.qr-reader-frame--active{border-style:solid;border-color:var(--color-primary);box-shadow:0 0 0 4px #0ea5e91a,var(--shadow-glow)}.qr-reader-frame--active:before,.qr-reader-frame--active:after{content:"";position:absolute;width:40px;height:40px;border-color:var(--color-primary);border-style:solid;pointer-events:none;z-index:10}.qr-reader-frame--active:before{top:12px;left:12px;border-width:4px 0 0 4px;border-radius:12px 0 0}.qr-reader-frame--active:after{bottom:12px;right:12px;border-width:0 4px 4px 0;border-radius:0 0 12px}.qr-reader{width:100%;height:100%}.scanner-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;text-align:center;color:var(--text-muted);padding:2rem;background:linear-gradient(145deg,var(--color-surface-alt) 0%,var(--color-surface) 100%)}.scanner-placeholder-icon{width:72px;height:72px;border-radius:var(--radius-xl);background:linear-gradient(135deg,#0ea5e914,#6366f10f);border:1px solid rgba(14,165,233,.15);display:grid;place-items:center}.scanner-placeholder-icon svg{width:36px;height:36px;color:var(--color-primary);opacity:.6}.scanner-placeholder p{margin:0;font-size:.9rem;max-width:240px;line-height:1.5}.scanner-placeholder .scan-line{width:60px;height:2px;background:linear-gradient(90deg,transparent,var(--color-primary),transparent);animation:scanLine 2s ease-in-out infinite;margin-top:.5rem}@keyframes scanLine{0%,to{opacity:.3;transform:scaleX(.8)}50%{opacity:1;transform:scaleX(1.2)}}.scan-status{text-align:center;font-size:.875rem;color:var(--text-muted);font-weight:500;position:relative;z-index:1;padding:.75rem;background:var(--color-surface-alt);border-radius:var(--radius-md);border:1px solid var(--color-border);flex-shrink:0}.scanner-scanning-overlay{position:absolute;inset:0;pointer-events:none;z-index:5;overflow:hidden;border-radius:var(--radius-xl)}.scanner-scanning-overlay:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--color-primary),transparent);animation:scanningLine 2s linear infinite;box-shadow:0 0 10px var(--color-primary)}@keyframes scanningLine{0%{top:0;opacity:0}10%{opacity:1}90%{opacity:1}to{top:100%;opacity:0}}.generator-preview-modern{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-2xl);padding:1.5rem;box-shadow:var(--shadow-sm);position:sticky;top:5rem}.preview-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.preview-header h3{margin:0;font-size:var(--fs-lg);font-weight:700;color:var(--text-strong)}.preview-badge-modern{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .75rem;background:linear-gradient(135deg,var(--color-primary-light) 0%,rgba(99,102,241,.1) 100%);border:1px solid var(--color-primary-soft);border-radius:999px;font-size:var(--fs-xs);font-weight:700;color:var(--color-primary);text-transform:uppercase;letter-spacing:.05em}.preview-content{display:flex;flex-direction:column;gap:1.25rem}.qr-display-modern{display:flex;justify-content:center;padding:1.5rem;background:linear-gradient(135deg,var(--color-surface-alt) 0%,var(--color-primary-muted) 100%);border-radius:var(--radius-xl);border:1px solid var(--color-border)}.qr-image-modern{width:100%;max-width:200px;border-radius:var(--radius-md);box-shadow:var(--shadow-md)}.qr-details{display:flex;flex-direction:column;gap:.5rem}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:.625rem .875rem;background:var(--color-surface-alt);border-radius:var(--radius-md);border:1px solid var(--color-border)}.detail-label{font-size:var(--fs-sm);color:var(--text-muted);font-weight:500}.detail-value{font-size:var(--fs-sm);color:var(--text-default);font-weight:600}.detail-value.highlight{color:var(--color-primary)}.qr-string-modern{padding:.875rem;background:var(--color-surface-alt);border-radius:var(--radius-md);border:1px solid var(--color-border);overflow-x:auto}.qr-string-modern code{font-size:var(--fs-xs);color:var(--text-muted);word-break:break-all}.preview-actions{display:flex;gap:.75rem}.btn-action{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;border-radius:var(--radius-md);border:none;font-weight:600;font-size:var(--fs-sm);cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden}.btn-action-primary{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-accent) 100%);color:#fff;box-shadow:0 4px 12px #0ea5e94d}.btn-action-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 18px #0ea5e966}.btn-action-primary:active:not(:disabled){transform:translateY(0)}.btn-action-primary:disabled{opacity:.5;cursor:not-allowed;background:var(--color-surface-muted);color:var(--text-muted);box-shadow:none}.btn-action-secondary{background:var(--color-surface-alt);color:var(--text-default);border:1px solid var(--color-border)}.btn-action-secondary:hover:not(:disabled){background:var(--color-surface);border-color:var(--color-border-strong);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.btn-action-secondary:active:not(:disabled){transform:translateY(0)}.btn-action-secondary:disabled{opacity:.5;cursor:not-allowed;background:var(--color-surface-muted)}.btn-action svg{flex-shrink:0}.preview-notice{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:linear-gradient(135deg,var(--color-primary-muted) 0%,rgba(99,102,241,.05) 100%);border:1px solid var(--color-primary-light);border-radius:var(--radius-md);font-size:var(--fs-xs);color:var(--color-primary);margin:0}.preview-notice svg{flex-shrink:0}.preview-placeholder-modern{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:3rem 1.5rem;text-align:center;color:var(--text-muted);min-height:300px}.placeholder-icon{opacity:.3;color:var(--text-muted)}.preview-placeholder-modern p{margin:0;font-size:var(--fs-sm)}.generating-indicator{display:flex;align-items:center;gap:.5rem;font-size:var(--fs-sm);color:var(--color-primary)}@media(max-width:640px){.generator-preview-modern{position:static;padding:1.25rem}.preview-actions{flex-direction:column}.btn-action{width:100%}.qr-display-modern{padding:1rem}.qr-image-modern{max-width:160px}}.qr-image-section{display:flex;justify-content:center;padding:1.5rem;background:linear-gradient(135deg,var(--color-surface-alt) 0%,var(--color-primary-muted) 100%);border-radius:var(--radius-xl);border:1px solid var(--color-border);margin-bottom:1.5rem}.qr-image-container{background:#fff;padding:1rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.qr-code-image{width:160px;height:160px;display:block}@media(max-width:640px){.qr-image-section{padding:1rem}.qr-code-image{width:140px;height:140px}}.parsed-fields-section{background:linear-gradient(145deg,var(--color-surface) 0%,var(--color-surface-alt) 100%);border:1px solid var(--color-border);border-radius:var(--radius-2xl);padding:1.5rem;box-shadow:var(--shadow-sm)}.parsed-fields-section .section-title{display:flex;align-items:center;gap:.75rem;margin:0 0 .5rem;font-size:1.1rem;font-weight:700;color:var(--text-strong)}.parsed-fields-section .section-title svg{width:22px;height:22px;color:var(--color-primary)}.fields-info{margin:0 0 1.25rem;font-size:.8rem;color:var(--text-muted);padding:.5rem .875rem;background:var(--color-surface-alt);border-radius:var(--radius-md);border:1px solid var(--color-border)}.fields-table{display:flex;flex-direction:column;gap:.625rem}.table-header{display:grid;grid-template-columns:70px 60px 1fr 1.2fr;gap:.75rem;padding:.625rem 1rem;background:linear-gradient(135deg,var(--color-surface-alt) 0%,var(--color-surface-muted) 100%);border-radius:var(--radius-lg);border:1px solid var(--color-border);font-size:.7rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.field-group{display:flex;flex-direction:column;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;transition:all .2s ease}.field-group:hover{border-color:var(--color-border-strong);box-shadow:var(--shadow-sm)}.field-group.is-expanded{border-color:var(--color-primary-soft);box-shadow:0 0 0 3px #0ea5e914}.table-row{display:grid;grid-template-columns:70px 60px 1fr 1.2fr;gap:.75rem;align-items:center;padding:.875rem 1rem;min-height:52px}.tag{display:flex;align-items:center;gap:.4rem;font-family:var(--font-mono);font-weight:700;font-size:.85rem}.tag-value{display:inline-flex;align-items:center;justify-content:center;min-width:36px;padding:.3rem .6rem;border-radius:var(--radius-sm);background:var(--color-surface-alt);border:1px solid var(--color-border);color:var(--text-default)}.tag--payment .tag-value{background:linear-gradient(135deg,#10b9811f,#10b9810f);border-color:#10b9814d;color:var(--color-success)}.tag--metadata .tag-value{background:linear-gradient(135deg,#f59e0b1f,#f59e0b0f);border-color:#f59e0b4d;color:#d97706}.tag--crc .tag-value{background:linear-gradient(135deg,#ef44441f,#ef44440f);border-color:#ef44444d;color:var(--color-danger)}.subtag-toggle{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-surface);color:var(--text-muted);font-size:.7rem;cursor:pointer;transition:all .2s ease;flex-shrink:0}.subtag-toggle:hover{background:var(--color-primary-muted);border-color:var(--color-primary-soft);color:var(--color-primary)}.length{font-family:var(--font-mono);font-size:.8rem;color:var(--text-muted);text-align:center}.value{font-family:var(--font-mono);font-size:.85rem;color:var(--text-default);word-break:break-word;display:flex;align-items:center;gap:.5rem}.value--with-copy{position:relative;padding-right:28px}.field-copy-btn{position:absolute;right:0;top:50%;transform:translateY(-50%);width:24px;height:24px;border-radius:var(--radius-sm);border:1px solid transparent;background:transparent;color:var(--text-muted);cursor:pointer;display:grid;place-items:center;opacity:0;transition:all .2s ease}.table-row:hover .field-copy-btn{opacity:1}.field-copy-btn:hover{background:var(--color-surface-alt);border-color:var(--color-border);color:var(--color-primary)}.description{font-size:.85rem;color:var(--text-muted);line-height:1.4}.subtag-table{background:var(--color-surface-alt);border-top:1px solid var(--color-border);padding:.75rem 1rem;display:flex;flex-direction:column;gap:.5rem}.subtag-header{display:grid;grid-template-columns:60px 50px 1fr 1.2fr;gap:.625rem;padding:.375rem .75rem;font-size:.65rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;background:#ffffff80;border-radius:var(--radius-sm)}.subtag-row{display:grid;grid-template-columns:60px 50px 1fr 1.2fr;gap:.625rem;align-items:center;padding:.5rem .75rem;background:var(--color-surface);border-radius:var(--radius-sm);border:1px solid var(--color-border);font-size:.8rem}.subtag-cell{font-family:var(--font-mono)}.subtag-cell--tag{color:var(--color-accent);font-weight:600;text-align:center}.subtag-cell--length{color:var(--text-muted);text-align:center}.subtag-cell--value{color:var(--text-default);word-break:break-word}.subtag-cell--description{color:var(--text-muted);font-family:var(--font-sans)}@media(max-width:768px){.parsed-fields-section{padding:1.25rem}.table-header{display:none}.table-row{grid-template-columns:1fr;gap:.5rem;padding:1rem}.table-row>*{display:flex;align-items:center;gap:.5rem}.table-row>*:before{font-weight:600;color:var(--text-muted);font-size:.75rem;text-transform:uppercase;min-width:80px}.tag:before{content:"Tag"}.length:before{content:"Length"}.value:before{content:"Value"}.description:before{content:"Description"}.subtag-header{display:none}.subtag-row{grid-template-columns:1fr;gap:.35rem;padding:.75rem}.subtag-row>*{display:flex;align-items:center;gap:.5rem}.subtag-row>*:before{font-weight:600;color:var(--text-muted);font-size:.7rem;text-transform:uppercase;min-width:80px}.subtag-cell--tag:before{content:"Sub-tag"}.subtag-cell--length:before{content:"Length"}.subtag-cell--value:before{content:"Value"}.subtag-cell--description:before{content:"Desc"}.field-copy-btn{opacity:1;position:static;transform:none}}.raw-data-section{background:linear-gradient(145deg,var(--color-surface) 0%,var(--color-surface-alt) 100%);border:1px solid var(--color-border);border-radius:var(--radius-2xl);padding:1.5rem;box-shadow:var(--shadow-sm);margin-bottom:1.5rem}.raw-data-section .section-title{display:flex;align-items:center;gap:.75rem;margin:0 0 1rem;font-size:1.1rem;font-weight:700;color:var(--text-strong)}.raw-data-section .section-title svg{width:22px;height:22px;color:var(--color-primary)}.raw-data{background:#0f172a;border-radius:var(--radius-lg);padding:1.25rem;border:1px solid #1e293b;overflow-x:auto}.raw-data code{display:block;font-family:var(--font-mono);font-size:.85rem;color:#e2e8f0;line-height:1.6;word-break:break-all;white-space:pre-wrap}@media(max-width:768px){.raw-data-section{padding:1.25rem}.raw-data{padding:1rem}.raw-data code{font-size:.8rem}}.qr-preview-card{background:linear-gradient(145deg,var(--color-surface) 0%,var(--color-surface-alt) 100%);border:1px solid var(--color-border);border-radius:var(--radius-2xl);box-shadow:var(--shadow-sm);overflow:hidden;position:sticky;top:2rem}.qr-preview-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;background:var(--color-surface);border-bottom:1px solid var(--color-border)}.qr-preview-title-group{display:flex;align-items:center;gap:.875rem}.qr-preview-type-icon{width:44px;height:44px;border-radius:var(--radius-lg);display:grid;place-items:center;flex-shrink:0}.qr-preview-type-icon svg{width:22px;height:22px}.qr-preview-title{margin:0;font-size:1rem;font-weight:700;color:var(--text-strong);letter-spacing:-.01em}.qr-preview-subtitle{display:block;font-size:.8rem;color:var(--text-muted);font-weight:500;margin-top:.125rem}.qr-preview-live-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:linear-gradient(135deg,#10b9811f,#0596691f);border:1px solid rgba(16,185,129,.25);border-radius:999px;font-size:.75rem;font-weight:700;color:var(--color-success);text-transform:uppercase;letter-spacing:.05em}.live-dot{width:6px;height:6px;background:var(--color-success);border-radius:50%;animation:pulse-live 2s ease-in-out infinite}@keyframes pulse-live{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.qr-preview-body{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.qr-preview-image-container{display:flex;justify-content:center;padding:1.5rem;background:linear-gradient(135deg,var(--color-surface-alt) 0%,var(--color-primary-muted) 100%);border-radius:var(--radius-xl);border:1px solid var(--color-border)}.qr-preview-image-wrapper{position:relative;background:#fff;padding:1rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.qr-preview-image{width:180px;height:180px;display:block;border-radius:var(--radius-sm)}.qr-preview-frame{position:absolute;inset:.5rem;pointer-events:none}.qr-frame-corner{position:absolute;width:24px;height:24px;border-color:var(--color-primary);border-style:solid;border-width:0;opacity:.4}.qr-frame-tl{top:0;left:0;border-top-width:3px;border-left-width:3px;border-top-left-radius:var(--radius-md)}.qr-frame-tr{top:0;right:0;border-top-width:3px;border-right-width:3px;border-top-right-radius:var(--radius-md)}.qr-frame-bl{bottom:0;left:0;border-bottom-width:3px;border-left-width:3px;border-bottom-left-radius:var(--radius-md)}.qr-frame-br{bottom:0;right:0;border-bottom-width:3px;border-right-width:3px;border-bottom-right-radius:var(--radius-md)}.qr-preview-details{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1rem}.qr-details-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.qr-detail-item{display:flex;flex-direction:column;gap:.25rem}.qr-detail-item-full{grid-column:span 2}.qr-detail-label{font-size:.7rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.qr-detail-value{font-size:.9rem;font-weight:600;color:var(--text-strong)}.qr-detail-mono{font-family:var(--font-mono);font-size:.85rem;word-break:break-all}.qr-detail-amount{color:var(--color-success);font-size:1.1rem;font-weight:700}.qr-preview-string-section{border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.qr-string-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;padding:.875rem 1rem;background:var(--color-surface-alt);border:none;font-size:.85rem;font-weight:600;color:var(--text-default);cursor:pointer;transition:background .2s ease}.qr-string-toggle:hover{background:var(--color-surface-muted)}.qr-preview-string{padding:1rem;background:#0f172a;border-top:1px solid var(--color-border);max-height:150px;overflow-y:auto}.qr-preview-string code{display:block;font-family:var(--font-mono);font-size:.8rem;color:#e2e8f0;line-height:1.6;word-break:break-all}.qr-preview-actions{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.qr-action-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1rem;border-radius:var(--radius-lg);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:1px solid transparent}.qr-action-btn:disabled{opacity:.6;cursor:not-allowed}.qr-action-btn-primary{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-strong) 100%);color:#fff;box-shadow:0 4px 14px #2563eb40}.qr-action-btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #2563eb59}.qr-action-btn-secondary{background:var(--color-surface);color:var(--text-default);border-color:var(--color-border)}.qr-action-btn-secondary:hover:not(:disabled){background:var(--color-surface-alt);border-color:var(--color-border-strong);transform:translateY(-2px)}.qr-btn-spinner{width:16px;height:16px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.qr-preview-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1.5rem;text-align:center;gap:.75rem}.qr-empty-icon{width:80px;height:80px;border-radius:var(--radius-xl);background:linear-gradient(135deg,var(--color-surface-alt) 0%,var(--color-primary-muted) 100%);border:1px solid var(--color-border);display:grid;place-items:center;color:var(--text-muted);margin-bottom:.5rem}.qr-empty-title{margin:0;font-size:1.1rem;font-weight:700;color:var(--text-strong)}.qr-empty-subtitle{margin:0;font-size:.85rem;color:var(--text-muted);max-width:240px}.qr-generating-indicator{display:flex;align-items:center;gap:.625rem;margin-top:.5rem;padding:.625rem 1rem;background:var(--color-primary-muted);border-radius:var(--radius-lg);font-size:.85rem;font-weight:600;color:var(--color-primary)}.qr-generating-spinner{width:18px;height:18px;border:2px solid var(--color-primary);border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite}@media(max-width:768px){.qr-preview-card{position:static;top:0}.qr-preview-header{padding:1rem 1.25rem}.qr-preview-body{padding:1.25rem}.qr-preview-image{width:160px;height:160px}.qr-details-grid{grid-template-columns:1fr}.qr-detail-item-full{grid-column:span 1}.qr-preview-actions{grid-template-columns:1fr}}@media(max-width:480px){.qr-preview-image{width:140px;height:140px}.qr-preview-image-container{padding:1rem}}
