*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%}body{background-color:#f0f0f0;display:flex;justify-content:center;align-items:center}.auth-container{height:100vh;width:100%;display:flex;justify-content:center;align-items:center;background:#233060;font-family:Poppins,sans-serif}.auth-inner{position:relative;width:100%;max-width:100%;height:100vh;display:flex;box-shadow:0 4px 18px #00000026;overflow:hidden}.split-wrapper{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:1250px;height:700px;overflow:hidden;border-radius:28px;box-shadow:0 10px 32px #00000040;background:#111}.split-wrapper{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:1250px;height:700px;overflow:hidden;border-radius:28px;box-shadow:0 10px 32px #00000040;background:#111;display:flex}.column{flex:1;height:100%;position:relative;overflow:hidden}.column-track{display:flex;width:200%;height:100%;transition:transform .7s cubic-bezier(.7,.05,.35,1)}.hero-track.login{transform:translate(0)}.hero-track.register{transform:translate(-50%)}.form-track.login{transform:translate(0)}.form-track.register{transform:translate(-50%)}.hero,.card-form{width:50%;height:100%}.hero{flex:none;position:relative;background-size:cover;background-position:center;display:flex;flex-direction:column;justify-content:space-between}.hero:after{content:"";position:absolute;inset:0;background:linear-gradient(160deg,#0000008c,#0003)}.hero-overlay{position:relative;z-index:2;color:#fff;padding:48px 52px;display:flex;flex-direction:column;justify-content:flex-start;gap:20px;max-width:480px}.hero-overlay h1{font-size:2.2rem;line-height:1.15;font-weight:700}.hero-overlay p{font-size:.95rem;opacity:.9}.hero-bottom-switch{position:relative;z-index:2;width:100%;display:flex;justify-content:center;align-items:center;padding:32px 20px}.hero-overlay .inline-switch,.hero-bottom-switch .inline-switch{margin:0;display:flex;flex-direction:column;align-items:center;gap:8px;color:#fff;font-size:1rem}.hero-overlay .inline-switch button,.hero-bottom-switch .inline-switch button{background:#ec6c4ef2;color:#fff;padding:14px 28px;border-radius:12px;font-size:1.1rem;font-weight:700;border:2px solid rgba(255,255,255,.3);box-shadow:0 4px 12px #0000004d;transition:all .3s ease;width:auto}.hero-overlay .inline-switch button:hover,.hero-bottom-switch .inline-switch button:hover{background:#c45144;border-color:#ffffff80;transform:translateY(-2px);box-shadow:0 6px 16px #0006;text-decoration:none}.card-form{flex:none;background:#fff;display:flex;justify-content:center;flex-direction:column;padding:2vh;position:relative;padding-bottom:90px;overflow-y:auto}.switch-bottom{position:absolute;right:32px;bottom:24px}.switch-btn{background:#ec6c4e;border:none;color:#fff;padding:16px 32px;font-size:1.15rem;font-weight:700;border-radius:12px;cursor:pointer;box-shadow:0 6px 18px #00000059;transition:background .3s ease,transform .2s ease}.switch-btn:hover{background:#c45144}.switch-btn:active{transform:scale(.94)}.card-form{flex:.9;background:#fff;display:flex;flex-direction:column;padding:2.2vh 4vh}.card-form h2{font-size:1.9rem;font-weight:700;margin:0 0 18px}.inline-switch{width:100%;display:flex;flex-direction:column;align-items:center;margin-top:18px;font-size:1rem}.inline-switch button{width:100%;background:none;border:none;color:#ec6c4e;font-weight:700;font-size:1.05rem;cursor:pointer}.inline-switch button:hover{text-decoration:underline}.section-form{display:flex;flex-direction:column;gap:6px;margin:12px 0}.section-form label{font-size:.75rem;font-weight:600;letter-spacing:.3px;text-transform:uppercase;color:#333}.section-form input{padding:12px 14px;font-size:.9rem;border:1px solid #d6d6d6;border-radius:10px;background:#fafafa;transition:border-color .25s ease,background .25s ease}.section-form input:focus{outline:none;border-color:#3082e0;background:#fff}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper input{width:100%;padding-right:42px}.password-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:transparent!important;border:none;cursor:pointer;padding:0;margin:0;display:flex;align-items:center;justify-content:center;color:#666;font-size:1rem;line-height:1;transition:color .2s ease}.password-toggle:hover{color:#ec6c4e;background:transparent!important}.password-toggle:focus{outline:none;background:transparent!important;color:#ec6c4e}.password-toggle:active{background:transparent!important}.password-toggle svg{width:18px;height:18px;display:block}.form-panel .password-toggle{margin:0!important;padding:0!important;background:transparent!important;border:none!important;box-shadow:none!important;color:inherit}.form-panel .password-toggle:hover,.form-panel .password-toggle:focus,.form-panel .password-toggle:active{background:transparent!important;color:#ec6c4e}.btn-row{display:flex;justify-content:flex-start;margin-top:4px}.form-panel button{margin-top:4px;padding:12px 24px;font-size:.95rem;background:#111;color:#fff;border:none;border-radius:24px;cursor:pointer;font-weight:600;letter-spacing:.5px;transition:background .3s ease,transform .2s ease}.form-panel button:hover:not(:disabled){background:#222}.form-panel button:active:not(:disabled){transform:scale(.95)}.form-panel button:disabled{opacity:.55;cursor:not-allowed}.status-msg{font-size:.8rem;margin-top:12px}.auth-tabs.bottom{position:absolute;bottom:14px;right:20px;display:flex;gap:10px}.auth-tabs.bottom button{background:#e7e7e7;border:none;padding:10px 16px;font-size:.75rem;font-weight:600;border-radius:40px;cursor:pointer;transition:background .3s ease,color .3s ease;letter-spacing:.5px}.auth-tabs.bottom button.active{background:#ec6c4e;color:#fff}.auth-tabs.bottom button:hover:not(.active){background:#d4d4d4}.auth-tabs{display:flex;gap:8px;margin-bottom:18px}.auth-tabs button{flex:1;background:#e7e7e7;border:none;padding:10px 12px;font-size:.95rem;font-weight:600;border-radius:8px;cursor:pointer;transition:background .3s ease,color .3s ease}.auth-tabs button.active{background:#ec6c4e;color:#fff}.auth-tabs button:hover:not(.active){background:#d4d4d4}.section-form{display:flex;flex-direction:column;gap:6px;margin:18px 0}.section-form label{font-size:.9rem;padding-left:8px;border-left:3px solid #EC6C4E;color:#1f1e1e}.section-form input{padding:10px 14px;font-size:.95rem;border:1px solid #cfcfcf;border-radius:6px;background:#fff;transition:border-color .25s ease,box-shadow .25s ease}.section-form input:focus{border-color:#3082e0;outline:none;box-shadow:0 0 4px #3d38372e}.btn-row{display:flex;justify-content:center;margin-top:4px}.form-panel button{margin-top:8px;padding:10px 18px;font-size:1rem;background-color:#ec6c4e;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:background-color .3s ease,transform .2s ease}.form-panel button:hover:not(:disabled){background-color:#c45144}.form-panel button:active:not(:disabled){transform:scale(.96)}.form-panel button:disabled{opacity:.6;cursor:not-allowed}.pane-image{display:flex;justify-content:center;align-items:center}.pane-image img{width:100%;max-width:460px;height:320px;object-fit:cover;border-radius:12px;box-shadow:0 6px 18px #00000026}.status-msg{text-align:center;font-size:.85rem;margin-top:12px;font-weight:500}.status-msg.success{color:#2d8a3d}.status-msg.error,.status-msg.exists{color:#c6483c}.btn-back a{position:fixed;top:1rem;left:1rem;font-size:2.2rem;color:#ec6c4e;transition:.3s ease;z-index:10}.btn-back a:hover{color:#c45144;transform:scale(1.06)}.recover-password{display:flex;justify-content:center;background-color:transparent}.forgot-password-btn{background:none;font-family:Poppins,sans-serif;border:none;color:#233060;font-weight:600;cursor:pointer;padding:0;font-size:.85rem}.forgot-password-btn:hover{text-decoration:underline}@media(max-width:1100px){.split-wrapper{height:560px}.hero-overlay{padding:40px 44px}.hero-overlay h1{font-size:1.9rem}}@media(max-width:900px){.split-wrapper{width:94%;height:540px}.scene{flex-direction:column}.hero{flex:1;min-height:45%}.card-form{flex:1;padding:32px 34px}.auth-tabs.bottom{position:static;margin:14px 0 0}}@media(max-width:640px){.split-wrapper{height:520px}.hero-overlay{padding:32px 30px}.card-form{padding:28px 26px}.hero-overlay h1{font-size:1.55rem}.card-form h2{font-size:1.5rem}}@media(max-width:480px){.auth-container{height:100%;min-height:100vh;padding:0}.auth-inner{height:100%;min-height:100vh}.split-wrapper{width:100%;max-width:100%;height:100%;min-height:100vh;border-radius:0;flex-direction:column}.form-column{display:none}.hero-column{flex:1;width:100%;height:auto;min-height:100vh;overflow-y:auto}.column-track.hero-track{width:200%;height:auto;min-height:100vh}.hero{width:50%;height:auto;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:60px 20px 40px}.hero-overlay{padding:20px 24px 16px;max-width:100%;width:100%;text-align:center;align-items:center;gap:8px;flex-shrink:0}.hero-overlay h1{font-size:1.6rem;line-height:1.2}.hero-overlay p{font-size:.9rem;margin-bottom:0}.hero .mobile-form-container{display:flex;flex-direction:column;width:90%;max-width:340px;background:linear-gradient(180deg,#ffffff7a,#ffffff4d);backdrop-filter:blur(10px) saturate(125%);-webkit-backdrop-filter:blur(10px) saturate(125%);border:1px solid rgba(255,255,255,.25);border-radius:16px;padding:24px 20px 28px;margin:16px 0 20px;z-index:3;box-shadow:0 6px 20px #0000002e;flex-shrink:0}.hero .mobile-form-container h2{font-size:1.4rem;font-weight:700;margin:0 0 12px;color:#111;text-align:center}.hero .mobile-form-container .section-form{margin:8px 0}.hero .mobile-form-container .section-form label{font-size:.7rem;color:#333}.hero .mobile-form-container .section-form input{padding:10px 12px;font-size:.85rem}.hero .mobile-form-container .btn-row{margin-top:8px}.hero .mobile-form-container .form-panel button{width:100%;padding:12px 20px;font-size:.95rem}.hero .mobile-form-container .inline-switch{margin-top:12px;font-size:.95rem}.hero .mobile-form-container .inline-switch button{font-size:1.05rem;font-weight:700;padding:8px 0}.hero .mobile-form-container .recover-password{margin-top:8px}.hero .mobile-form-container .forgot-password-btn{font-size:.8rem}.hero .mobile-form-container .status-msg{font-size:.75rem;margin-top:8px}.hero .mobile-form-container .password-input-wrapper{position:relative;width:100%}.hero .mobile-form-container .password-input-wrapper input{width:100%;padding-right:40px}.hero .mobile-form-container .password-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:transparent!important;border:none;padding:4px;width:auto;min-width:unset;color:#666;line-height:1}.hero .mobile-form-container .password-toggle:hover{background:transparent!important;color:#ec6c4e}.hero .mobile-form-container .password-toggle:active,.hero .mobile-form-container .password-toggle:focus{background:transparent!important}.hero .mobile-form-container .password-toggle svg{width:18px;height:18px}.hero .mobile-form-container .form-panel .password-toggle{width:auto;padding:4px}.btn-back a{font-size:1.8rem;top:12px;left:12px}}@media(max-width:375px){.hero{padding:50px 16px 30px}.hero-overlay{padding:16px 20px 12px}.hero-overlay h1{font-size:1.4rem}.hero-overlay p{font-size:.85rem}.hero .mobile-form-container{width:92%;padding:20px 16px;margin:12px 0 16px}.hero .mobile-form-container h2{font-size:1.25rem}.hero .mobile-form-container .section-form input{padding:9px 10px;font-size:.8rem}.hero .mobile-form-container .password-toggle svg{width:16px;height:16px}}@media(min-width:414px)and (max-width:480px){.hero-overlay h1{font-size:1.8rem}.hero .mobile-form-container{max-width:360px;padding:28px 24px}}@media(min-width:481px){.card-form .recover-password{margin-top:18px}}:root{--bg-color: #233060;--card-bg-top: #efeeee;--card-bg-bottom: #dadadb;--primary-text: #1a1a1a;--secondary-text: #666;--accent-color: #8b4513;--progress-color: #EC6C4E;--success-color: #22c55e}.perfil-container{width:100%;min-height:100vh;min-height:-webkit-fill-available;background:var(--bg-color);font-family:Poppins,sans-serif;display:flex;justify-content:center;align-items:flex-start;padding:40px 16px;box-sizing:border-box;overflow-y:auto}.perfil-container-inner{width:100%;max-width:420px;position:relative;display:flex;flex-direction:column;gap:16px;margin:auto}.logout-container{display:flex;justify-content:flex-end;width:100%}.logout-button{display:flex;align-items:center;gap:6px;background:linear-gradient(135deg,#8b4513,sienna);color:#fff;border:none;padding:8px 16px;border-radius:20px;font-size:.85rem;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #0003;transition:transform .2s ease,box-shadow .2s ease;z-index:10}.logout-button:hover{transform:translateY(-2px);box-shadow:0 6px 15px #0000004d}.ticket-card{width:100%;background:linear-gradient(145deg,var(--card-bg-top) 0%,var(--card-bg-bottom) 100%);border-radius:24px;box-shadow:0 20px 50px #00000040;padding:24px;position:relative;overflow:hidden;box-sizing:border-box}.ticket-card:before{content:"";position:absolute;bottom:0;left:0;right:0;height:8px;background:linear-gradient(90deg,#8b4513,#d2691e,peru)}.ticket-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:10px}.ticket-id{display:flex;align-items:center;gap:10px}.ticket-id .icon{width:40px;height:auto;object-fit:contain}.ticket-id .id-text{font-size:1.1rem;font-weight:700;color:var(--primary-text)}.ticket-date{font-size:.75rem;font-weight:600;color:var(--secondary-text);background:#ffffff80;padding:4px 8px;border-radius:8px}.ticket-info-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.info-block{text-align:center;flex:1}.info-label{font-size:.7rem;font-weight:600;color:#888;text-transform:uppercase;margin-bottom:4px}.info-value{font-size:.95rem;font-weight:700;color:var(--primary-text)}.ticket-divider{display:flex;flex-direction:column;align-items:center;color:#ccc;padding:0 10px}.divider-line{width:1px;height:10px;background:#ccc}.status-indicator{display:flex;align-items:center;justify-content:center;gap:8px;padding:6px 12px;background:#22c55e1a;border-radius:20px;width:fit-content;margin:0 auto 24px}.status-dot{width:8px;height:8px;background:var(--success-color);border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%{box-shadow:0 0 #22c55e66}70%{box-shadow:0 0 0 6px #22c55e00}to{box-shadow:0 0 #22c55e00}}.status-text{font-size:.8rem;font-weight:700;color:var(--success-color);text-transform:uppercase}.ticket-details{background:#fff;border-radius:16px;padding:20px;margin-bottom:24px;box-shadow:inset 0 2px 6px #00000008;text-align:center}.detail-row{margin-bottom:16px;border-bottom:1px dashed #eee;padding-bottom:16px}.detail-label{display:block;font-size:.7rem;font-weight:600;color:#999;text-transform:uppercase;margin-bottom:6px}.detail-value{font-size:clamp(1.1rem,4vw,1.4rem);font-weight:800;color:var(--primary-text)}.detail-number{font-size:2rem;font-weight:800;color:var(--accent-color);line-height:1}.progress-section{margin-bottom:24px}.progress-header{display:flex;justify-content:space-between;margin-bottom:8px;font-size:.8rem;font-weight:700}.progress-label{color:#888}.progress-count{color:var(--primary-text)}.progress-bar-container{height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--progress-color);border-radius:4px;transition:width 1s cubic-bezier(.4,0,.2,1);position:relative}.ticket-qr-section{background:#fff;padding:0;border-radius:16px;border:2px dashed #ddd;margin-bottom:20px;display:flex;justify-content:center;align-items:center;overflow:hidden}.qr-container{width:100%;aspect-ratio:1;display:flex;justify-content:center;align-items:center}.qr-container svg,.qr-container canvas,.qr-container img{width:100%!important;height:100%!important;object-fit:cover}.ticket-footer{border-top:1px solid rgba(0,0,0,.05);padding-top:16px}.footer-info{display:flex;flex-direction:column;gap:8px}.footer-item{display:flex;align-items:center;gap:10px;color:var(--secondary-text);font-size:.8rem}@media(max-width:360px){.perfil-container{padding:20px 10px}.ticket-card{padding:16px}.detail-value{font-size:1.1rem}.ticket-id .id-text{font-size:1rem}}.recover-password-container{display:flex;justify-content:center;align-items:center;min-height:100vh;width:100%;background:#233060;font-family:Poppins,sans-serif;padding:20px;box-sizing:border-box}.recover-password-inner{position:relative;font-family:Poppins,sans-serif;width:100%;max-width:450px;height:auto;min-height:400px;background-color:#ebebeb;border-radius:12px;display:flex;flex-direction:column;box-shadow:0 4px 18px #0003;overflow:hidden;align-items:center;padding:30px 25px;box-sizing:border-box}.recover-password-inner h2{margin-top:10px;margin-bottom:15px;font-size:1.5rem;color:#333;text-align:center}.recover-header-img{width:100%;height:140px;object-fit:contain;border-radius:8px;margin-bottom:15px;background-color:transparent}.recover-password-inner form{width:100%;display:flex;flex-direction:column;align-items:center}.recover-password-inner label{align-self:flex-start;margin-bottom:8px;font-weight:600;font-size:.95rem;border-left:4px solid #EC6C4E;padding-left:10px;color:#333}.recover-password-inner p{font-size:.9rem;margin:0 0 20px;font-family:Poppins,sans-serif;color:#555;line-height:1.4;text-align:left;width:100%}.recover-password-inner input{width:100%;padding:12px;margin-bottom:20px;border:1px solid #ccc;border-radius:6px;font-size:1rem;box-sizing:border-box}.recover-password-form button,.recover-password-code-form button{width:100%;max-width:200px;padding:12px 20px;background-color:#ec6c4e;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .3s ease}.recover-password-form .btn-code{width:100%;display:flex;justify-content:center;margin-top:5px}.recover-password-form button:hover,.recover-password-code-form button:hover{background-color:#c45144}.recover-password-form button:disabled{background-color:#e0a095;cursor:not-allowed}.recover-password-code-form{display:flex;flex-direction:column;align-items:center;width:100%}.code-inputs-wrapper{display:flex;justify-content:space-between;gap:5px;width:100%;margin-bottom:20px}.code-input{width:100%!important;max-width:50px;height:60px;font-size:1.5rem;text-align:center;border:1px solid #ccc;border-radius:5px;padding:0}.logout-button-2{position:absolute;top:15px;left:15px;background:transparent;color:#333;border:none;cursor:pointer;z-index:5;padding:5px;display:flex;align-items:center;justify-content:center;transition:transform .2s ease,color .2s ease}.logout-button-2:hover{transform:scale(1.1);color:#ec6c4e}.logout-button-2:active{transform:scale(.95)}@media(max-width:380px){.recover-password-inner{padding:20px 15px;width:95%}.recover-header-img{height:100px}.recover-password-inner h2{font-size:1.3rem}.code-input{height:50px;font-size:1.2rem}}@media(min-width:381px)and (max-width:600px){.recover-header-img{height:130px}}.reset-password-container{display:flex;justify-content:center;align-items:center;min-height:100vh;width:100%;background:#233060;font-family:Poppins,sans-serif;padding:20px;box-sizing:border-box}.reset-password-inner{position:relative;width:100%;max-width:450px;background:#ebebeb;border-radius:12px;box-shadow:0 4px 18px #0003;padding:30px 25px;display:flex;flex-direction:column;align-items:center;overflow:hidden}.reset-header-img{width:100%;height:140px;object-fit:contain;margin-bottom:15px;background:transparent}.reset-password-inner h2{margin:10px 0 15px;font-size:1.5rem;color:#333;text-align:center}.subtitle{font-size:.9rem;margin-bottom:20px;color:#555;text-align:center;width:100%}.reset-password-form{width:100%;display:flex;flex-direction:column;gap:15px}.reset-password-form label{font-weight:600;font-size:.95rem;border-left:4px solid #EC6C4E;padding-left:10px;color:#333}.password-field-wrapper{position:relative;display:flex;align-items:center;width:100%}.reset-password-form input{width:100%;padding:12px 45px 12px 14px;border:1px solid #ccc;border-radius:6px;font-size:1rem;background:#fff;box-sizing:border-box}.reset-password-form input:focus{outline:none;border-color:#ec6c4e;box-shadow:0 0 0 2px #ec6c4e1a}.toggle-password-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:transparent!important;border:none;padding:0;display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:#666;cursor:pointer;transition:color .2s ease,transform .2s ease;z-index:5}.toggle-password-btn:hover{color:#ec6c4e;background:transparent!important;transform:translateY(-50%) scale(1.1)}.toggle-password-btn:active{transform:translateY(-50%) scale(.95)}.btn-reset-password{display:flex;justify-content:center;margin-top:10px}.btn-reset-password button{width:100%;max-width:200px;background:#ec6c4e;color:#fff;padding:12px 20px;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .3s ease}.btn-reset-password button:hover{background:#c45144}.btn-reset-password button:disabled{background:#e0a095;cursor:not-allowed}.back-button{position:absolute;top:15px;left:15px;background:transparent;border:none;cursor:pointer;color:#333;padding:5px;display:flex;align-items:center;justify-content:center;transition:transform .2s ease,color .2s ease;z-index:10}.back-button:hover{transform:scale(1.1);color:#ec6c4e}.back-button:active{transform:scale(.95)}.status-msg{font-size:.9rem;padding:8px 12px;border-radius:4px}.status-msg.error{color:#a94442;background-color:#f2dede;border:1px solid #ebccd1}.status-msg.success{color:#3c763d;background-color:#dff0d8;border:1px solid #d6e9c6}@media(max-width:480px){.reset-password-container{padding:15px}.reset-password-inner{padding:25px 20px;width:100%}.reset-header-img{height:110px}.reset-password-inner h2{font-size:1.3rem}.subtitle{font-size:.85rem}.back-button{top:10px;left:10px}}
