:root{--primary:#6c63ff;--primary-dark:#5a52e0;--primary-light:#ede9fe;--success:#10b981;--danger:#ef4444;--bg:#f5f4ff;--card:#fff;--text:#1e1b4b;--muted:#6b7280;--border:#e5e7eb;--radius:14px;--shadow:0 4px 24px #6c63ff14;--shadow-lg:0 10px 40px #6c63ff2e}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;background:#f5f4ff;background:var(--bg);color:#1e1b4b;color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,sans-serif;min-height:100vh}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.93)}to{opacity:1;transform:scale(1)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes blobDrift{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-20px) scale(1.06)}66%{transform:translate(-20px,15px) scale(.95)}}@keyframes spin{to{transform:rotate(1turn)}}@keyframes shimmer{0%{background-position:-500px 0}to{background-position:500px 0}}@keyframes pop{0%{opacity:0;transform:scale(.8)}60%{transform:scale(1.06)}to{opacity:1;transform:scale(1)}}@keyframes shake{0%,to{transform:translateX(0)}20%{transform:translateX(-6px)}40%{transform:translateX(6px)}60%{transform:translateX(-4px)}80%{transform:translateX(4px)}}@keyframes cardIn{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.auth-wrap{align-items:center;background:linear-gradient(135deg,#f5f4ff,#ede9fe 50%,#fce7f3);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:24px;position:relative}.auth-blob{animation:blobDrift 9s ease-in-out infinite;border-radius:50%;filter:blur(64px);pointer-events:none;position:absolute}.auth-blob-1{background:#6c63ff2e;height:420px;left:-120px;top:-120px;width:420px}.auth-blob-2{animation-delay:-4.5s;background:#ff658424;bottom:-80px;height:320px;right:-60px;width:320px}.auth-card{animation:scaleIn .4s cubic-bezier(.34,1.56,.64,1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffffeb;border:1px solid #ffffffbf;border-radius:24px;box-shadow:0 24px 64px #6c63ff24,inset 0 1px 0 #fffc;max-width:420px;padding:44px 38px 36px;position:relative;width:100%;z-index:1}.auth-logo{animation:float 3.5s ease-in-out infinite;display:block;font-size:3rem;margin-bottom:10px;text-align:center}.auth-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#6c63ff,#9333ea);background:linear-gradient(135deg,var(--primary),#9333ea);-webkit-background-clip:text;background-clip:text;font-size:1.9rem;font-weight:800;letter-spacing:-.5px;margin-bottom:8px;text-align:center}.auth-subtitle{color:#6b7280;color:var(--muted);font-size:.875rem;line-height:1.55;margin-bottom:26px;min-height:2.8em;text-align:center;transition:all .3s}.auth-tabs{background:#f3f4f6;border-radius:10px;display:flex;gap:4px;margin-bottom:24px;padding:4px}.auth-tab{background:#0000;border:none;border-radius:8px;color:#6b7280;color:var(--muted);cursor:pointer;flex:1 1;font-size:.88rem;font-weight:600;padding:9px;transition:all .22s ease}.auth-tab.active{background:#fff;box-shadow:0 2px 8px #0000001a;color:#6c63ff;color:var(--primary)}.auth-switch{color:#6b7280;color:var(--muted);font-size:.83rem;margin-top:18px;text-align:center}.link-btn{background:none;border:none;color:#6c63ff;color:var(--primary);cursor:pointer;font-size:inherit;font-weight:600;text-decoration:underline;text-underline-offset:2px;transition:opacity .15s}.link-btn:hover{opacity:.7}.label-optional{color:#6b7280;color:var(--muted);font-size:.8em;font-weight:400}.req{color:#ef4444;color:var(--danger)}.form-group{margin-bottom:16px}.form-group label{color:#1e1b4b;color:var(--text);display:block;font-size:.8rem;font-weight:600;letter-spacing:.01em;margin-bottom:6px}.form-group input{background:#fafafa;border:1.5px solid #e5e7eb;border:1.5px solid var(--border);border-radius:10px;color:#1e1b4b;color:var(--text);font-size:.93rem;outline:none;padding:11px 14px;transition:border-color .2s,box-shadow .2s,transform .15s;width:100%}.form-group input:focus{background:#fff;border-color:#6c63ff;border-color:var(--primary);box-shadow:0 0 0 3px #6c63ff1f;transform:translateY(-1px)}.form-group input.input-error{border-color:#ef4444;border-color:var(--danger);box-shadow:0 0 0 3px #ef44441a}.form-group input.input-success{border-color:#10b981;border-color:var(--success);box-shadow:0 0 0 3px #10b9811a}.input-eye{align-items:center;display:flex;position:relative}.input-eye input{padding-right:44px}.eye-btn{background:none;border:none;cursor:pointer;font-size:1.1rem;line-height:1;padding:0;position:absolute;right:12px;transition:transform .2s;-webkit-user-select:none;user-select:none}.eye-btn:hover{transform:scale(1.25) rotate(-5deg)}.eye-btn:active{transform:scale(.9)}.field-msg{font-size:.8rem;margin-top:5px}.field-error{color:#ef4444;color:var(--danger)}.field-success{color:#10b981;color:var(--success)}.form-alert{border-radius:9px;font-size:.84rem;font-weight:500;margin-bottom:14px;padding:10px 14px}.form-alert-error{animation:shake .38s ease;background:#fef2f2;border-left:3px solid #ef4444;border-left:3px solid var(--danger);color:#ef4444;color:var(--danger)}.form-alert-success{background:#ecfdf5;border-left:3px solid #10b981;border-left:3px solid var(--success);color:#10b981;color:var(--success)}.anim-pop{animation:pop .35s ease}.btn{align-items:center;border:none;border-radius:10px;cursor:pointer;display:inline-flex;font-size:.88rem;font-weight:600;gap:6px;justify-content:center;padding:10px 20px;text-decoration:none;transition:transform .15s,box-shadow .15s,opacity .15s;white-space:nowrap}.btn:hover{transform:translateY(-2px)}.btn:active{transform:scale(.97)}.btn:disabled{cursor:not-allowed;opacity:.52;transform:none!important}.btn-primary{background:linear-gradient(135deg,#6c63ff,#764ba2);box-shadow:0 4px 14px #6c63ff52;color:#fff}.btn-primary:hover{box-shadow:0 6px 22px #6c63ff7a}.btn-full{width:100%}.btn-generate{font-size:.96rem;margin-top:4px;padding:13px 28px}.btn-save{background:#ecfdf5;border:1px solid #6ee7b7;color:#059669;font-size:.8rem;padding:6px 12px}.btn-save:hover{background:#d1fae5}.btn-danger{background:#fef2f2;border:1px solid #fca5a5;color:#ef4444;color:var(--danger);font-size:.8rem;padding:6px 12px}.btn-danger:hover{background:#fee2e2}.btn-dl{background:#eff6ff;border:1px solid #93c5fd;color:#2563eb;font-size:.8rem;padding:6px 12px}.btn-dl:hover{background:#dbeafe}.btn-signout{background:#f3f4f6;border:1px solid #e5e7eb;border:1px solid var(--border);color:#6b7280;color:var(--muted);font-size:.83rem;padding:8px 16px}.btn-signout:hover{background:#e5e7eb}.btn-spinner{animation:spin .65s linear infinite;border:2px solid #ffffff59;border-radius:50%;border-top-color:#fff;display:inline-block;flex-shrink:0;height:15px;width:15px}.top-bar{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#ffffffdb;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border);box-shadow:0 1px 14px #0000000d;justify-content:space-between;padding:14px 36px;position:sticky;top:0;z-index:100}.top-bar,.top-brand{align-items:center;display:flex}.top-brand{gap:10px}.brand-icon{animation:float 3.5s ease-in-out infinite;display:inline-block;font-size:1.55rem}.brand-name{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#6c63ff,#9333ea);background:linear-gradient(135deg,var(--primary),#9333ea);-webkit-background-clip:text;background-clip:text;font-size:1.2rem;font-weight:800;letter-spacing:-.3px}.top-right{align-items:center;display:flex;gap:14px}.top-user{color:#6b7280;color:var(--muted);font-size:.83rem;font-weight:500}.app{min-height:100vh}.main-content{margin:0 auto;max-width:1060px;padding:40px 28px 72px}.hero{animation:fadeSlideUp .5s ease both;padding:20px 0 36px;text-align:center}.hero-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#1e1b4b,#6c63ff);background:linear-gradient(135deg,#1e1b4b 0,var(--primary) 100%);-webkit-background-clip:text;background-clip:text;font-size:2.6rem;font-weight:800;letter-spacing:-1px;margin-bottom:12px}.hero-sub{color:#6b7280;color:var(--muted);font-size:1.05rem;line-height:1.65;margin:0 auto;max-width:480px}.create-card{animation:fadeSlideUp .5s ease .1s both;background:#fff;background:var(--card);border:1px solid #e5e7eb;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius);box-shadow:0 4px 24px #6c63ff14;box-shadow:var(--shadow);margin-bottom:40px;padding:32px}.create-card-header{align-items:flex-start;display:flex;gap:16px;margin-bottom:26px}.create-icon{align-items:center;animation:float 4s ease-in-out infinite;background:#ede9fe;background:var(--primary-light);border-radius:12px;display:inline-flex;flex-shrink:0;font-size:1.5rem;height:46px;justify-content:center;width:46px}.create-card-header h2{color:#1e1b4b;color:var(--text);font-size:1.18rem;font-weight:700;margin-bottom:3px}.create-desc{color:#6b7280;color:var(--muted);font-size:.84rem;line-height:1.5}.create-form{display:flex;flex-direction:column}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr;margin-bottom:0}.colors-row{align-items:end;grid-template-columns:1fr 1fr auto;margin-top:0}.color-pick{align-items:center;background:#fafafa;border:1.5px solid #e5e7eb;border:1.5px solid var(--border);border-radius:10px;cursor:pointer;display:flex;gap:10px;padding:9px 13px;transition:border-color .2s}.color-pick:hover{border-color:#6c63ff;border-color:var(--primary)}.color-pick input[type=color]{background:none;border:none;border-radius:6px;cursor:pointer;height:30px;padding:0;width:30px}.color-hex{color:#6b7280;color:var(--muted);font-family:Courier New,monospace;font-size:.8rem;letter-spacing:.04em}.create-layout{grid-gap:32px;align-items:start;display:grid;gap:32px;grid-template-columns:1fr 220px}.colors-row{grid-template-columns:1fr 1fr}.preview-side{position:sticky;top:80px}.preview-panel{align-items:center;background:linear-gradient(160deg,#faf9ff,#f0eeff);border:1.5px solid #6c63ff26;border-radius:18px;box-shadow:0 4px 24px #6c63ff14;display:flex;flex-direction:column;gap:14px;padding:22px 18px 20px;transition:box-shadow .3s}.preview-panel:hover{box-shadow:0 8px 32px #6c63ff24}.preview-pill{background:#6c63ff1a;border:1px solid #6c63ff33;border-radius:999px;color:#6c63ff;color:var(--primary);font-size:.68rem;font-weight:700;letter-spacing:.1em;padding:4px 12px;text-transform:uppercase}.preview-qr-wrap{border-radius:12px;box-shadow:0 6px 24px #0000001f;overflow:hidden;transition:transform .35s cubic-bezier(.34,1.56,.64,1),box-shadow .3s}.preview-qr-wrap:hover{box-shadow:0 12px 36px #0000002e;transform:scale(1.05) rotate(-1deg)}.preview-info{align-items:center;display:flex;flex-direction:column;gap:8px;width:100%}.preview-name{color:#1e1b4b;color:var(--text);font-size:.88rem;font-weight:700;max-width:180px;overflow:hidden;text-align:center;text-overflow:ellipsis;white-space:nowrap}.preview-placeholder{color:#6b7280;color:var(--muted);font-style:italic;font-weight:400}.preview-swatches{align-items:center;display:flex;gap:6px}.preview-swatch{border-radius:50%;box-shadow:0 1px 4px #0000002e;display:inline-block;height:16px;transition:transform .2s;width:16px}.preview-swatch:hover{transform:scale(1.3)}.preview-swatch-bg{border:1.5px solid #e5e7eb;border:1.5px solid var(--border)}.preview-dest{background:#ffffffb3;border:1px solid #e5e7eb;border:1px solid var(--border);border-radius:999px;color:#6b7280;color:var(--muted);font-size:.7rem;max-width:180px;overflow:hidden;padding:4px 10px;text-align:center;text-overflow:ellipsis;white-space:nowrap;width:100%}.preview-group{display:flex;flex-direction:column}.preview-group label{margin-bottom:6px}.library-header{align-items:center;animation:fadeSlideUp .5s ease .2s both;display:flex;gap:12px;margin-bottom:20px}.library-title{color:#1e1b4b;color:var(--text);font-size:1.25rem;font-weight:700}.library-badge{background:#ede9fe;background:var(--primary-light);border-radius:999px;color:#6c63ff;color:var(--primary);font-size:.78rem;font-weight:600;padding:3px 12px}.skeleton-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.skeleton-card{animation:shimmer 1.4s ease-in-out infinite;background:linear-gradient(90deg,#ececec 25%,#e0e0e0 50%,#ececec 75%);background-size:500px 100%;border-radius:14px;border-radius:var(--radius);height:340px}.empty-state{animation:fadeSlideUp .5s ease both;padding:80px 24px;text-align:center}.empty-icon{animation:float 3.2s ease-in-out infinite;display:block;font-size:4.5rem;margin-bottom:18px}.empty-state h3{color:#1e1b4b;color:var(--text);font-size:1.3rem;font-weight:700;margin-bottom:8px}.empty-state p{color:#6b7280;color:var(--muted);font-size:.93rem;line-height:1.6}.qr-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.qr-card{animation:cardIn .45s ease both;background:#fff;background:var(--card);border:1px solid #e5e7eb;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius);box-shadow:0 4px 24px #6c63ff14;box-shadow:var(--shadow);overflow:hidden;transition:transform .25s ease,box-shadow .25s ease}.qr-card:hover{box-shadow:0 10px 40px #6c63ff2e;box-shadow:var(--shadow-lg);transform:translateY(-6px)}.qr-card-top{align-items:center;display:flex;justify-content:center;min-height:190px;padding:28px 24px}.qr-card-top img{background:#fff;border-radius:10px;box-shadow:0 6px 20px #0000002e;height:138px;padding:8px;transition:transform .3s ease;width:138px}.qr-card:hover .qr-card-top img{transform:scale(1.05) rotate(-1deg)}.qr-card-body{display:flex;flex-direction:column;gap:10px;padding:18px 20px 22px}.qr-name{color:#1e1b4b;color:var(--text);font-size:1rem;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.qr-meta-row{align-items:center;display:flex;justify-content:space-between}.scan-badge{background:#ede9fe;background:var(--primary-light);border-radius:999px;color:#6c63ff;color:var(--primary);font-size:.75rem;font-weight:600;padding:3px 10px}.qr-date{font-size:.74rem}.qr-date,.qr-dest{color:#6b7280;color:var(--muted)}.qr-dest{font-size:.8rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.qr-dest a{color:#6c63ff;color:var(--primary);text-decoration:none}.qr-dest a:hover{text-decoration:underline}.url-edit{display:flex;flex-direction:column;gap:8px}.url-edit input{background:#fafafa;border:1.5px solid #e5e7eb;border:1.5px solid var(--border);border-radius:8px;font-size:.82rem;outline:none;padding:8px 11px;transition:border-color .2s;width:100%}.url-edit input:focus{background:#fff;border-color:#6c63ff;border-color:var(--primary)}.card-actions{display:flex;flex-wrap:wrap;gap:6px}@media (max-width:780px){.create-layout{grid-template-columns:1fr}.preview-side{position:static}.preview-panel{flex-direction:row;flex-wrap:wrap;justify-content:center;padding:16px}}@media (max-width:680px){.top-bar{padding:12px 18px}.main-content{padding:24px 16px 56px}.hero-title{font-size:1.9rem}.create-card{padding:22px 18px}.colors-row{grid-template-columns:1fr 1fr}.top-user{display:none}.auth-card{padding:32px 22px 28px}}
/*# sourceMappingURL=main.82245458.css.map*/