:root{color:#0f172a;background:#f8fafc;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;overflow-x:hidden;background:radial-gradient(circle at 8% -8%,rgba(191,219,254,.62),transparent 26rem),radial-gradient(circle at 96% 26%,rgba(224,231,255,.38),transparent 30rem),#f8fafc;line-height:1.5}button,input{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed}:where(a,button,summary):focus-visible{outline:3px solid #bfdbfe;outline-offset:3px;border-radius:6px}.site-shell{width:min(1180px,calc(100% - 48px));margin:0 auto;padding:28px 0 42px}.topbar{display:flex;align-items:center;justify-content:flex-start}.brand{display:inline-flex;align-items:center;gap:11px;color:#0f172a;font-weight:760;font-size:1rem;letter-spacing:-.035em;text-decoration:none}.brand-mark{display:grid;grid-template-columns:repeat(2,7px);grid-template-rows:repeat(2,7px);gap:3px;padding:6px;border-radius:9px;background:linear-gradient(145deg,#0f172a,#1e3a8a);box-shadow:0 7px 18px #0f172a2e}.brand-mark i{display:block;background:#fcfbf8}.brand-mark i:nth-child(2){border-radius:0 0 3px}.brand-mark i:nth-child(3){border-radius:0 3px 0 0}.brand-mark i:nth-child(4){background:#60a5fa}.hero{position:relative;isolation:isolate;padding:70px 0 54px;max-width:750px}.hero:before{position:absolute;z-index:-1;top:16px;left:-74px;width:370px;height:220px;border-radius:50%;background:radial-gradient(ellipse,#bfdbfe85,#bfdbfe00 70%);content:"";filter:blur(10px);pointer-events:none}.hero h1{max-width:650px;margin:0 0 18px;color:#0f172a;font-size:clamp(2rem,3.5vw,3rem);line-height:1.08;letter-spacing:-.055em;font-weight:780;text-wrap:balance}.hero h1 span{color:#1d4ed8;background:linear-gradient(100deg,#dbeafe,#eff6ff);box-decoration-break:clone;-webkit-box-decoration-break:clone}.hero p{max-width:610px;margin:0;color:#475569;font-size:1.125rem;line-height:1.55;letter-spacing:-.012em}.workspace{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(400px,.95fr);gap:28px;align-items:stretch}.controls-card,.preview-card{border-radius:24px}.controls-card{position:relative;overflow:hidden;padding:32px;border:1px solid transparent;background:linear-gradient(#fff,#fff) padding-box,linear-gradient(135deg,#3b82f68c,#e2e8f0e6 52%,#a5b4fc94) border-box;box-shadow:0 24px 60px #1e293b17}.controls-card:before{position:absolute;top:-112px;right:-80px;width:250px;height:220px;border-radius:50%;background:radial-gradient(circle,#bfdbfe52,#bfdbfe00 70%);content:"";pointer-events:none}.controls-card>*{position:relative}.card-heading{margin-bottom:28px}.card-heading h2{margin:0;color:#0f172a;font-size:1.5rem;line-height:1.2;letter-spacing:-.04em}.field-group{margin-bottom:25px}.field-group>label,.label-row>label,.range-field label{display:block;color:#344054;font-size:.875rem;font-weight:730;letter-spacing:-.01em}.label-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:9px}.label-row>label span{margin-left:4px;color:#98a2b3;font-weight:500}.text-button{padding:0;border:0;background:transparent;color:#52647c;font-size:.8125rem;font-weight:700}.text-button:hover:not(:disabled){color:#101828;text-decoration:underline;text-underline-offset:3px}.text-button:disabled{color:#b5bdc9}.text-input-wrap{position:relative;margin-top:9px}.text-input-wrap svg{position:absolute;top:50%;left:14px;width:18px;height:18px;fill:none;stroke:#98a2b3;stroke-linecap:round;stroke-linejoin:round;stroke-width:1.8;transform:translateY(-50%);pointer-events:none}input[type=text]{width:100%;min-height:52px;padding:12px 14px;border:1px solid #d8dce2;border-radius:10px;outline:none;color:#182230;background:#fff;font-size:1rem;line-height:1.5;transition:border-color .18s,box-shadow .18s}.text-input-wrap input{padding-left:43px}input[type=text]:hover{border-color:#b8c0cc}input[type=text]:focus{border-color:#2563eb;box-shadow:0 0 0 3px #dbeafe}input[aria-invalid=true]{border-color:#d92d20}.field-help{margin:7px 0 0;color:#98a2b3;font-size:.75rem;line-height:1.45}.field-error{margin:7px 0 0;color:#d92d20;font-size:.8125rem;font-weight:600}.upload-zone{display:flex;align-items:center;gap:11px;min-height:78px;padding:11px 13px;border:1px dashed #b7c2d0;border-radius:13px;background:linear-gradient(125deg,#f8fafc,#f5f8ff);cursor:pointer;transition:border-color .18s,background .18s,box-shadow .18s,transform .18s}.upload-zone:hover{border-color:#5b8def;background:linear-gradient(125deg,#f8fbff,#eff6ff);box-shadow:0 8px 18px #2563eb14;transform:translateY(-1px)}.upload-zone:focus-within{border-color:#2563eb;box-shadow:0 0 0 3px #dbeafe}.upload-icon{display:grid;width:36px;height:36px;flex:0 0 36px;place-items:center;border-radius:9px;background:#eff6ff;color:#2563eb}.upload-icon svg{width:19px;height:19px;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:1.8}.upload-copy{display:grid;gap:3px;min-width:0}.upload-copy strong{overflow:hidden;color:#344054;font-size:.875rem;font-weight:700;text-overflow:ellipsis;white-space:nowrap}.upload-copy small{color:#98a2b3;font-size:.75rem}.change-label{margin-left:auto;color:#52647c;font-size:.8125rem;font-weight:700}.color-group{margin-bottom:23px}.color-controls{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.color-control{display:flex;align-items:center;gap:10px;padding:10px 11px;border:1px solid #e1e4e8;border-radius:12px;background:#fcfcfd;cursor:pointer;transition:border-color .18s,box-shadow .18s,transform .18s}.color-control:hover{border-color:#aebbc9;box-shadow:0 7px 14px #1018280f;transform:translateY(-1px)}.color-control:focus-within{border-color:#2563eb;box-shadow:0 0 0 3px #dbeafe}.color-control>span:nth-child(2){display:grid;gap:2px;min-width:0}.color-control strong{color:#475467;font-size:.8125rem;font-weight:700}.color-control small{color:#98a2b3;font-size:.75rem;letter-spacing:.02em}.swatch{width:23px;height:23px;flex:0 0 23px;border:1px solid #d8dce2;border-radius:7px;background:#101828}.swatch.white{background:#fff}input[type=color]{width:0;height:0;padding:0;border:0;opacity:0;position:absolute}.advanced-controls{margin:0 -2px 26px;border-top:1px solid #ebedf0;border-bottom:1px solid #ebedf0}.advanced-controls summary{display:flex;align-items:center;justify-content:space-between;padding:17px 2px;color:#475467;cursor:pointer;font-size:.875rem;font-weight:730;list-style:none}.advanced-controls summary::-webkit-details-marker{display:none}.advanced-controls summary svg{width:17px;height:17px;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:1.8;transition:transform .2s}.advanced-controls[open] summary svg{transform:rotate(180deg)}.advanced-inner{padding:0 2px 18px}.range-field{padding:10px 0 14px}.range-field>div{display:flex;justify-content:space-between;align-items:center;margin-bottom:9px}.range-field output{color:#667085;font-size:.75rem;font-weight:650}.range-field.is-disabled{opacity:.45}input[type=range]{width:100%;height:4px;margin:0;accent-color:#2563eb;cursor:pointer}input[type=range]:disabled{cursor:not-allowed}.filename-field{margin:8px 0 0}.filename-field>label{margin-bottom:9px}.download-button{display:inline-flex;width:100%;min-height:54px;align-items:center;justify-content:center;gap:9px;padding:14px 18px;border:1px solid #2563eb;border-radius:13px;color:#fff;background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 6px #1e40af,0 14px 26px #2563eb3d;font-size:1rem;font-weight:790;letter-spacing:-.01em;transition:filter .18s,transform .18s,box-shadow .18s}.download-button:hover:not(:disabled){filter:saturate(1.08) brightness(1.03);box-shadow:0 4px #1e40af,0 16px 28px #2563eb4d;transform:translateY(2px)}.download-button:active:not(:disabled){box-shadow:0 1px #1e40af;transform:translateY(5px)}.download-button:disabled{border-color:#c5cbd3;color:#667085;background:#e4e7ec;box-shadow:none}.download-button svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:1.8}.preview-card{display:flex;position:relative;min-height:620px;flex-direction:column;isolation:isolate;overflow:hidden;padding:22px;border:1px solid rgba(147,197,253,.3);color:#f8fafc;background:linear-gradient(145deg,#0f172a,#172554 53%,#102a4c);box-shadow:0 26px 60px #0f172a40}.preview-card:before{position:absolute;z-index:-1;top:-160px;right:-120px;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,#3b82f647,#3b82f600 70%);content:"";pointer-events:none}.preview-topline,.preview-footer{display:flex;align-items:center;justify-content:space-between;gap:12px}.preview-label{display:inline-flex;align-items:center;gap:7px;color:#dce4f0;font-size:.75rem;font-weight:800;letter-spacing:.08em}.pulse{width:6px;height:6px;border-radius:50%;background:#60a5fa;box-shadow:0 0 0 4px #60a5fa1f}.format-label{color:#8c9bae;font-size:.75rem;font-weight:650}.qr-stage{display:grid;position:relative;flex:1;min-height:400px;place-items:center;margin:22px 0;padding:clamp(26px,5vw,55px);border:1px solid rgba(191,219,254,.12);border-radius:18px;background:radial-gradient(circle at 22% 16%,#315576,#1e3a5f 54%,#122a4b)}.qr-stage:before,.qr-stage:after{content:"";position:absolute;width:41px;height:41px;border-color:#60a5fa99;pointer-events:none}.qr-stage:before{top:20px;left:20px;border-top:1px solid;border-left:1px solid;border-radius:4px 0 0}.qr-stage:after{right:20px;bottom:20px;border-right:1px solid;border-bottom:1px solid;border-radius:0 0 4px}#qr-canvas,#qr-transition-canvas{display:block;grid-area:1 / 1;width:min(100%,395px);height:auto;border-radius:5px;background:#fff;box-shadow:0 22px 38px #00000040;image-rendering:pixelated}#qr-transition-canvas{opacity:0;pointer-events:none;transition:opacity .18s ease-out}#qr-transition-canvas.is-static{opacity:1;transition:none}.empty-state{display:grid;grid-area:1 / 1;place-items:center;gap:10px;color:#b7c5d4;text-align:center}.empty-state[hidden]{display:none}.empty-state span{color:#60a5fa;font-size:40px;line-height:.8}.empty-state p{margin:0;font-size:.875rem}.preview-footer{min-height:39px}.encoded-value{display:grid;min-width:0;gap:4px}.encoded-value span{color:#8c9bae;font-size:.75rem;font-weight:800;letter-spacing:.1em}.encoded-value strong{overflow:hidden;max-width:262px;color:#f0f3f7;font-size:.875rem;font-weight:600;text-overflow:ellipsis;white-space:nowrap}.scan-note{display:inline-flex;flex:0 0 auto;align-items:center;gap:5px;color:#93c5fd;font-size:.75rem;font-weight:700}.scan-note svg,.local-note svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:1.8}.site-footer{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:7px;margin-top:28px;color:#778190;font-size:.8125rem}.local-note{display:flex;align-items:center;gap:7px;margin:0}.local-note svg{color:#2563eb}.copyright{color:#52647c;font-weight:700;text-decoration-color:#c4cad3;text-underline-offset:3px}.copyright:hover{color:#101828}.toast{position:fixed;z-index:3;bottom:24px;left:50%;max-width:min(400px,calc(100% - 36px));padding:11px 14px;border:1px solid #bfdbfe;border-radius:9px;color:#1d4ed8;background:#eff6ff;box-shadow:0 10px 25px #1018281f;font-size:.875rem;font-weight:650;opacity:0;pointer-events:none;transform:translate(-50%,18px);transition:opacity .2s,transform .2s}.toast.is-error{border-color:#f1c0bc;color:#b42318;background:#fffbfa}.toast.is-visible{opacity:1;transform:translate(-50%)}@media(max-width:820px){.site-shell{width:min(100% - 32px,620px);padding-top:22px}.hero{padding:52px 0 36px}.hero h1{font-size:clamp(2rem,7vw,2.25rem)}.hero p{font-size:1rem}.workspace{grid-template-columns:1fr}.preview-card{order:-1;min-height:500px}.qr-stage{min-height:370px}}@media(max-width:480px){.site-shell{width:min(100% - 24px,620px)}.privacy-note{display:none}.controls-card,.preview-card{border-radius:20px}.controls-card{padding:24px}.preview-card{padding:15px;min-height:420px}.qr-stage{min-height:315px;margin:15px 0;padding:31px}.qr-stage:before{top:13px;left:13px}.qr-stage:after{right:13px;bottom:13px}.color-controls{grid-template-columns:1fr}.card-heading{margin-bottom:23px}.encoded-value strong{max-width:190px}.site-footer{text-align:center}.local-note{align-items:flex-start;line-height:1.4}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}
