@import url(https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap);:root{--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen,Ubuntu,Cantarell,"Open Sans","Helvetica Neue",sans-serif;--primary:#4f46e5;--primary-hover:#4338ca;--secondary:#ec4899;--success:#10b981;--danger:#ef4444;--warning:#f59e0b;--bg-color:#f3f4f6;--card-bg:#fff;--text-main:#111827;--text-muted:#6b7280;--border-color:#e5e7eb;--radius-sm:0.375rem;--radius-md:0.75rem;--radius-lg:1rem;--radius-xl:1.5rem;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;--shadow-glow:0 0 15px #4f46e54d}*,:after,:before{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f3f4f6;background-color:var(--bg-color);color:#111827;color:var(--text-main);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;font-family:var(--font-sans);line-height:1.5;margin:0;padding:0}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.2;margin:0}p{margin:0 0 1rem}img,video{display:block;height:auto;max-width:100%}button,input,select,textarea{font-family:inherit}.App{background:radial-gradient(circle at top right,#e0e7ff,#f3f4f6 40%);display:flex;flex-direction:column;min-height:100vh;padding:2rem 1rem}header{animation:fadeInDown .8s ease-out;margin-bottom:3rem;text-align:center}header h1{color:var(--primary);font-size:3rem;letter-spacing:-.02em;margin-bottom:.5rem}.subtitle{color:var(--text-muted);font-size:1.125rem;font-weight:400}.main-container{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr;margin:0 auto;max-width:1200px;width:100%}@media (min-width:992px){.main-container{align-items:start;grid-template-columns:repeat(2,1fr)}}.card{animation:fadeInUp .8s ease-out;background:var(--card-bg);border:1px solid #fffc;border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);overflow:hidden;padding:2rem;position:relative;transition:transform .3s ease,box-shadow .3s ease}.card:hover{box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;transform:translateY(-5px)}.card h2{border-bottom:2px solid var(--bg-color);color:var(--text-main);display:inline-block;font-size:1.5rem;margin-bottom:1.5rem;padding-bottom:.75rem;width:100%}.textarea-container{margin-bottom:1.5rem;position:relative}textarea{background:#f9fafb;border:2px solid var(--border-color);border-radius:var(--radius-md);font-size:1rem;height:120px;padding:1rem;resize:none;transition:border-color .2s,box-shadow .2s;width:100%}textarea:focus{background:#fff;border-color:var(--primary);box-shadow:0 0 0 4px #4f46e51a;outline:none}.char-counter{background:#fffc;border-radius:4px;bottom:.75rem;color:var(--text-muted);font-size:.75rem;padding:2px 6px;position:absolute;right:.75rem}.options{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:1fr;margin-bottom:2rem}.options>div{display:flex;flex-direction:column;gap:.5rem}.options label{color:var(--text-muted);font-size:.875rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}input[type=file],input[type=range],select{width:100%}select{-webkit-appearance:none;appearance:none;background-color:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;font-size:.95rem;padding:.75rem 2.5rem .75rem 1rem;transition:all .2s}select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a;outline:none}input[type=file]{color:var(--text-muted);font-size:.875rem}input[type=file]::-webkit-file-upload-button{background:var(--bg-color);border:none;border-radius:var(--radius-sm);color:var(--text-main);cursor:pointer;font-weight:600;margin-right:1rem;padding:.6rem 1rem;-webkit-transition:background .2s;transition:background .2s}input[type=file]::file-selector-button{background:var(--bg-color);border:none;border-radius:var(--radius-sm);color:var(--text-main);cursor:pointer;font-weight:600;margin-right:1rem;padding:.6rem 1rem;transition:background .2s}input[type=file]::-webkit-file-upload-button:hover{background:#e5e7eb}input[type=file]::file-selector-button:hover{background:#e5e7eb}input[type=range]{appearance:none;-webkit-appearance:none;background:#0000}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;background:var(--primary);border-radius:50%;box-shadow:0 2px 6px #0003;cursor:pointer;height:20px;margin-top:-8px;width:20px}input[type=range]::-webkit-slider-runnable-track{background:var(--border-color);border-radius:2px;cursor:pointer;height:4px;width:100%}button{align-items:center;background:var(--primary);border:none;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);color:#fff;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;justify-content:center;padding:.875rem 1.5rem;transition:all .2s;width:100%}button:hover:not(:disabled){background:var(--primary-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}button:active:not(:disabled){transform:translateY(0)}button:disabled{background:var(--text-muted);cursor:not-allowed;opacity:.6}.result{animation:fadeIn .5s ease-out;border-top:1px dashed var(--border-color);margin-top:2rem;padding-top:2rem;text-align:center}.result h3{color:var(--text-main);margin-bottom:1rem}.result img{border:4px solid #fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);margin-bottom:1.5rem;max-width:100%}.download-btn{background:var(--text-main);margin-top:.5rem}.download-btn:hover{background:#000}.decode-options{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.camera-section,.file-upload-section{background:var(--bg-color);border:1px solid #0000;border-radius:var(--radius-lg);padding:1.5rem;transition:border-color .2s}.camera-section:hover,.file-upload-section:hover{border-color:var(--border-color)}.camera-section h3,.file-upload-section h3{color:var(--text-main);font-size:1.125rem;margin-bottom:1rem}.camera-container{align-items:center;background:#000;border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:1rem;margin-top:1rem;padding:1rem}.video-wrapper{border-radius:var(--radius-md);box-shadow:0 0 0 2px #ffffff1a;max-width:480px;overflow:hidden;position:relative;width:100%}.camera-video{display:block;width:100%}.overlay-guide{border:2px solid #fffc;border-radius:20px;box-shadow:0 0 0 9999px #00000080;height:200px;left:50%;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);width:200px}.overlay-guide:after{border:2px dashed #ffffff80;border-radius:20px;content:"";inset:-2px;position:absolute}.scanning-indicator{align-items:center;background:#ffffff1a;border-radius:2rem;color:#fff;display:flex;font-size:.875rem;gap:.5rem;padding:.5rem 1rem}.scanning-indicator p{line-height:1;margin:0}.scanning-indicator.scanning:before{animation:pulse 1.5s infinite;background:var(--success);border-radius:50%;content:"";display:block;height:8px;width:8px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%{box-shadow:0 0 0 0 #10b981b3;transform:scale(.95)}70%{box-shadow:0 0 0 10px #10b98100;transform:scale(1)}to{box-shadow:0 0 0 0 #10b98100;transform:scale(.95)}}.primary-button{background:var(--success)}.primary-button:hover{background:#059669}.stop-button{background:var(--danger)}.stop-button:hover{background:#dc2626}.error{animation:fadeIn .3s;background:#fef2f2;border-left:4px solid var(--danger);border-radius:var(--radius-md);color:var(--danger);margin-left:auto;margin-right:auto;margin-top:2rem;max-width:600px;padding:1rem;text-align:center}.mobile-qr-section{align-items:center;border-top:1px dashed var(--border-color);display:flex;flex-direction:column;margin-top:2rem;padding-top:2rem}.mobile-qr-section h3{color:var(--text-main);font-size:1.125rem;margin-bottom:1.5rem;text-align:center}.qr-container{align-items:center;background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);display:flex;flex-direction:column;padding:1rem}.qr-container img{display:block;height:150px;margin-bottom:.5rem;object-fit:contain;width:150px}.qr-hint{color:var(--text-muted);font-size:.875rem;margin:0;text-align:center}@media (max-width:640px){header h1{font-size:2rem}.card{padding:1.5rem}}.mobile-scanner-container{background-color:#000;color:#fff;display:flex;flex-direction:column;height:100vh;height:100dvh;left:0;position:fixed;top:0;width:100vw;z-index:9999}.scanner-header{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#00000080;display:flex;justify-content:space-between;padding:1rem;position:absolute;top:0;width:100%;z-index:10}.scanner-header h2{color:#fff;font-size:1.25rem;margin:0}.close-scanner-btn{background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:1.2rem;height:36px;padding:0;width:36px}.close-scanner-btn,.scanner-viewport{align-items:center;display:flex;justify-content:center}.scanner-viewport{flex:1 1;overflow:hidden;position:relative}.scanner-viewport .overlay-guide{height:70vw;max-height:400px;max-width:400px;width:70vw}.full-screen-video{border-radius:0;box-shadow:none;height:100%;max-width:none;width:100%}.full-screen-video img.frozen,.full-screen-video video{display:block;height:100%;object-fit:cover;width:100%}.scanner-footer{align-items:center;background:#000c;border-top-left-radius:20px;border-top-right-radius:20px;display:flex;flex-direction:column;justify-content:center;min-height:auto;padding:2rem 1rem calc(2rem + env(safe-area-inset-bottom, 20px))}.scanner-result{text-align:center;width:100%}.scanner-result h3{color:#aaa;font-size:.9rem;letter-spacing:1px;margin-top:0;text-transform:uppercase}.scanner-result a,.scanner-result p{color:#fff;display:block;font-size:1.5rem;margin:1rem 0;text-decoration:none;word-break:break-all}.scanner-result a{color:var(--primary);text-decoration:underline}.error-message{background:#ff00001a;border-radius:8px;color:#ff6b6b;margin-top:1rem;padding:.5rem 1rem}
/*# sourceMappingURL=main.1e5230d4.css.map*/