body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--primary-color:#4a6cf7;--primary-dark:#3a56d4;--success-color:#10b981;--error-color:#ef4444;--warning-color:#f59e0b;--background-color:#f8fafc;--card-background:#fff;--text-primary:#1e293b;--text-secondary:#64748b;--text-light:#94a3b8;--border-color:#e2e8f0;--border-radius:12px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow:0 4px 6px -1px #0000001a;--shadow-md:0 10px 15px -3px #0000001a;--shadow-lg:0 20px 25px -5px #0000001a;--transition:all 0.3s ease}*{box-sizing:border-box;margin:0;padding:0}body{background-color:#f8fafc;background-color:var(--background-color);color:#1e293b;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;line-height:1.6}.App,body{min-height:100vh}.App{display:flex;flex-direction:column;margin:0 auto;max-width:900px;padding:2rem 1rem}.App-header{margin-bottom:2.5rem;padding:1rem;text-align:center}.App-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#4a6cf7,#7c3aed);background:linear-gradient(135deg,var(--primary-color),#7c3aed);-webkit-background-clip:text;background-clip:text;font-size:2.2rem;font-weight:700;letter-spacing:-.5px;margin-bottom:.5rem}.App-subtitle{color:#64748b;color:var(--text-secondary);font-size:1.1rem;font-weight:400}.navigation-tabs{background:#fff;background:var(--card-background);border-radius:12px;border-radius:var(--border-radius);box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow);gap:1rem;margin-bottom:2.5rem;margin-left:auto;margin-right:auto;max-width:400px;padding:.5rem}.navigation-tabs,.tab-button{display:flex;justify-content:center}.tab-button{align-items:center;background:#0000;border:none;border-radius:8px;color:#64748b;color:var(--text-secondary);cursor:pointer;flex:1 1;font-size:1rem;font-weight:600;gap:.5rem;padding:.875rem 1.5rem;transition:all .3s ease;transition:var(--transition)}.tab-button:hover{background:#f1f5f9;color:#1e293b;color:var(--text-primary);transform:translateY(-1px)}.tab-button.active{background:#4a6cf7;background:var(--primary-color);box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow);color:#fff}.tab-icon{font-size:1.1rem}.main-content{flex:1 1}.footer-note{border-top:1px solid #e2e8f0;border-top:1px solid var(--border-color);color:#94a3b8;color:var(--text-light);font-size:.9rem;margin-top:2rem;padding:1.5rem 0}.container,.footer-note{text-align:center}.container h2{color:#1e293b;color:var(--text-primary);font-size:1.6rem;font-weight:600;margin-bottom:.75rem}.instructions{color:#64748b;color:var(--text-secondary);font-size:1rem;line-height:1.7;margin-bottom:2rem;margin-left:auto;margin-right:auto;max-width:600px}.instructions strong{color:#4a6cf7;color:var(--primary-color);font-weight:600}.pattern-indicator{display:flex;gap:1.5rem;justify-content:center;margin:2rem 0}.indicator-dot{align-items:center;background:#e2e8f0;background:var(--border-color);color:#94a3b8;color:var(--text-light);display:flex;font-weight:700;height:2.5rem;justify-content:center;position:relative;width:2.5rem}.indicator-dot,.indicator-dot:before{border-radius:50%;transition:all .3s ease;transition:var(--transition)}.indicator-dot:before{border:2px solid #0000;content:"";height:100%;position:absolute;width:100%}.indicator-dot.active{background:#4a6cf7;background:var(--primary-color);color:#fff;transform:scale(1.1)}.indicator-dot.active:before{animation:pulse 2s infinite;border-color:#4a6cf74d}.indicator-dot.loading{animation:loading 1.5s infinite;background:linear-gradient(90deg,#e2e8f0 25%,#e2e8f0 50%,#e2e8f0 75%);background:linear-gradient(90deg,var(--border-color) 25%,#e2e8f0 50%,var(--border-color) 75%);background-size:200% 100%}@keyframes pulse{0%,to{opacity:1;transform:scale(1.1)}50%{opacity:.7;transform:scale(1.2)}}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.image-wrapper{display:inline-block;margin:1.5rem 0;overflow:hidden;position:relative}.image-wrapper,.password-image{border-radius:12px;border-radius:var(--border-radius)}.password-image{border:2px solid #e2e8f0;border:2px solid var(--border-color);cursor:crosshair;display:block;height:auto;max-width:90vw;transition:all .3s ease;transition:var(--transition);width:500px}.password-image:hover{border-color:#4a6cf7;border-color:var(--primary-color);box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.password-image.loading{cursor:wait;opacity:.7}.click-marker{align-items:center;animation:pop .3s cubic-bezier(.175,.885,.32,1.275);background:#4a6cf7;background:var(--primary-color);border:3px solid #fff;border-radius:50%;box-shadow:0 0 0 2px #4a6cf7,0 4px 12px #00000026;box-shadow:0 0 0 2px var(--primary-color),0 4px 12px #00000026;color:#fff;display:flex;font-size:1rem;font-weight:700;height:2.5rem;justify-content:center;pointer-events:none;position:absolute;width:2.5rem;z-index:10}@keyframes pop{0%{opacity:0;transform:scale(0)}70%{transform:scale(1.2)}to{opacity:1;transform:scale(1)}}.message{align-items:center;animation:slideDown .4s cubic-bezier(.175,.885,.32,1.275);box-shadow:0 4px 12px #0000001a;display:flex;font-size:1rem;font-weight:600;gap:.75rem;justify-content:center;left:0;max-width:100%;padding:1rem 1.5rem;position:fixed;right:0;text-align:center;top:0;z-index:1000}.message.success{background:#d1fae5;border-bottom:3px solid #10b981;color:#065f46}.message.error{background:#fee2e2;border-bottom:3px solid #ef4444;color:#991b1b}@keyframes slideDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.status-info{align-items:center;background:#fff;background:var(--card-background);border-radius:12px;border-radius:var(--border-radius);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);display:flex;gap:2rem;justify-content:center;margin:1.5rem 0;padding:1.25rem}.status-info p{color:#64748b;color:var(--text-secondary);font-size:1.1rem;margin:0}.status-info strong{color:#4a6cf7;color:var(--primary-color);font-size:1.3rem;margin-left:.25rem}.reset-button{align-items:center;background:#64748b;background:var(--text-secondary);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s ease;transition:var(--transition)}.reset-button:hover{background:#475569;box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow);transform:translateY(-2px)}.reset-button:active{transform:translateY(0)}.tips{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-left:4px solid #4a6cf7;border-left:4px solid var(--primary-color);border-radius:12px;border-radius:var(--border-radius);margin-left:auto;margin-right:auto;margin-top:2rem;max-width:600px;padding:1.5rem;text-align:left}.tips h4{align-items:center;color:#3a56d4;color:var(--primary-dark);display:flex;font-size:1.1rem;gap:.5rem;margin-bottom:.75rem}.tips ul{list-style:none;padding-left:0}.tips li{color:#64748b;color:var(--text-secondary);margin-bottom:.5rem;padding-left:1.5rem;position:relative}.tips li:before{color:#4a6cf7;color:var(--primary-color);content:"•";font-weight:700;left:0;position:absolute}.success-pulse{animation:successPulse 2s infinite}@keyframes successPulse{0%,to{box-shadow:0 0 0 0 #10b98166}70%{box-shadow:0 0 0 10px #10b98100}}.shake{animation:shake .5s cubic-bezier(.36,.07,.19,.97) both}@keyframes shake{10%,90%{transform:translateX(-1px)}20%,80%{transform:translateX(2px)}30%,50%,70%{transform:translateX(-2px)}40%,60%{transform:translateX(2px)}}@media (max-width:768px){.App{padding:1.5rem 1rem}.App-title{font-size:1.8rem}.App-subtitle{font-size:1rem}.navigation-tabs{flex-direction:column;gap:.5rem;max-width:300px}.password-image{max-width:100%;width:100%}.status-info{flex-direction:column;gap:1rem;text-align:center}.pattern-indicator{gap:1rem}.click-marker,.indicator-dot{font-size:.9rem;height:2rem;width:2rem}.container h2{font-size:1.4rem}.message{font-size:.95rem;padding:.875rem 1rem}}@media (max-width:480px){.App{padding:1rem .75rem}.App-title{font-size:1.6rem}.tab-button{font-size:.95rem;padding:.75rem 1rem}.password-image{border-width:1px}.message{font-size:.9rem;padding:.75rem 1rem}.reset-button{font-size:.9rem;padding:.625rem 1.25rem}}.popup-overlay{align-items:center;animation:fadeIn .3s ease;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:2000}.popup{animation:popIn .3s cubic-bezier(.175,.885,.32,1.275);background:#fff;border-radius:12px;border-radius:var(--border-radius);box-shadow:0 20px 25px -5px #0000001a;box-shadow:var(--shadow-lg);max-width:400px;overflow:hidden;width:90%}.popup.success{border-top:4px solid #10b981;border-top:4px solid var(--success-color)}.popup.error{border-top:4px solid #ef4444;border-top:4px solid var(--error-color)}.popup-header{align-items:center;background:#f8fafc;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:1rem 1.5rem}.popup-icon{font-size:1.5rem}.popup-close{align-items:center;background:none;border:none;border-radius:50%;color:#64748b;color:var(--text-secondary);cursor:pointer;display:flex;font-size:1.8rem;height:30px;justify-content:center;line-height:1;padding:0;transition:all .3s ease;transition:var(--transition);width:30px}.popup-close:hover{background:#e2e8f0}.popup-close:hover,.popup-content{color:#1e293b;color:var(--text-primary)}.popup-content{font-size:1.1rem;line-height:1.6;padding:2rem 1.5rem;text-align:center}.popup-footer{background:#f8fafc;border-top:1px solid #e2e8f0;border-top:1px solid var(--border-color);padding:1rem 1.5rem;text-align:center}.popup-ok-button{background:#4a6cf7;background:var(--primary-color);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;min-width:100px;padding:.75rem 2rem;transition:all .3s ease;transition:var(--transition)}.popup-ok-button:hover{background:#3a56d4;background:var(--primary-dark);transform:translateY(-2px)}@keyframes popIn{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.password-image:focus-visible,button:focus-visible{outline:3px solid #4a6cf7;outline:3px solid var(--primary-color);outline-offset:2px}.password-image:focus{border-color:#4a6cf7;border-color:var(--primary-color)}.loading-state{opacity:.7;pointer-events:none}.page-transition{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.visually-hidden{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.text-center{text-align:center}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.flex{display:flex}.items-center{align-items:center}.justify-center{justify-content:center}.gap-2{gap:.5rem}.gap-4{gap:1rem}#dark-mode-checkbox{display:none}.dark-mode-label{align-items:center;background:#fff;background:var(--card-background);border:2px solid #e2e8f0;border:2px solid var(--border-color);border-radius:50%;box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow);cursor:pointer;display:flex;font-size:1.5rem;height:50px;justify-content:center;position:fixed;right:20px;top:20px;transition:all .3s ease;transition:var(--transition);width:50px;z-index:1000}.dark-mode-label:hover{transform:scale(1.1)}.dark-mode-label:before{content:"🌙"}#dark-mode-checkbox:checked~.dark-mode-label:before{content:"☀️"}#dark-mode-checkbox:checked~*{--primary-color:#60a5fa;--primary-dark:#3b82f6;--success-color:#34d399;--error-color:#f87171;--warning-color:#fbbf24;--background-color:#0f172a;--card-background:#1e293b;--text-primary:#f1f5f9;--text-secondary:#cbd5e1;--text-light:#94a3b8;--border-color:#334155;--shadow-sm:0 1px 2px 0 #0000004d;--shadow:0 4px 6px -1px #0006;--shadow-md:0 10px 15px -3px #00000080;--shadow-lg:0 20px 25px -5px #0009}#dark-mode-checkbox:checked~body{background-color:#f8fafc;background-color:var(--background-color);color:#1e293b;color:var(--text-primary)}*{transition:background-color .3s ease,color .3s ease,border-color .3s ease,box-shadow .3s ease}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}
/*# sourceMappingURL=main.1af866a7.css.map*/