@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{background:#7f7f7f;font-family:Inter,Arial,sans-serif}button,input{font-family:inherit}.login-page{background:#f5f5f5;min-height:812px;padding:135px 16px 24px}.login-card{background:#fff;border:1px solid #cfd8e3;border-radius:9px;width:100%;padding:22px 22px 24px;box-shadow:0 6px 18px #0f172a14}.login-logo{border-radius:11px;width:58px;height:58px;margin:0 auto 8px;overflow:hidden}.login-logo img{object-fit:cover;width:100%;height:100%;display:block}.app-name{text-align:center;color:#005894;margin:0 0 28px;font-size:18px;font-weight:700}.login-card h2{color:#171717;margin:0 0 7px;font-size:23px;font-weight:800;line-height:1.2}.login-desc{color:#6b7280;margin:0 0 22px;font-size:14px;line-height:1.4}.login-form{flex-direction:column;display:flex}.form-group{margin-bottom:18px}.form-group label{color:#6b7280;letter-spacing:.8px;margin-bottom:8px;font-size:11px;font-weight:800;display:block}.form-group input{color:#111827;background:#fff;border:1px solid #cfd8e3;border-radius:4px;outline:none;width:100%;height:52px;padding:0 14px;font-size:16px}.form-group input::placeholder{color:#8b95a5}.password-field{position:relative}.password-field input{padding-right:46px}.eye-button{color:#7b8491;cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;display:flex;position:absolute;top:50%;right:14px;transform:translateY(-50%)}.login-button{color:#fff;cursor:pointer;background:#005894;border:none;border-radius:6px;width:100%;height:54px;margin-top:3px;font-size:17px;font-weight:800}.forgot-button{color:#005894;cursor:pointer;background:0 0;border:none;margin-top:23px;font-size:14px;font-weight:500}.login-footer{text-align:center;color:#8b95a5;margin:24px 0 0;font-size:13px}.field-error{color:#dc2626;margin-top:6px;font-size:13px;font-weight:500}.login-error{color:#dc2626;margin-bottom:12px;font-size:13px;font-weight:500}.login-button:disabled,.forgot-button:disabled,.eye-button:disabled,.form-group input:disabled{cursor:not-allowed;opacity:.7}.login-popup-overlay{z-index:999;background:#0f172a8c;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.login-popup{text-align:center;background:#fff;border:1px solid #dc26261f;border-radius:14px;width:100%;max-width:315px;padding:30px 24px 28px;position:relative;box-shadow:0 18px 45px #0f172a59}.login-popup:before{content:"!";color:#dc2626;background:#fee2e2;border-radius:50%;justify-content:center;align-items:center;width:54px;height:54px;margin:0 auto 14px;font-size:30px;font-weight:800;display:flex}.login-popup-close{color:#6b7280;cursor:pointer;background:0 0;border:none;width:28px;height:28px;font-size:22px;font-weight:700;line-height:1;position:absolute;top:10px;right:12px}.login-popup-close:hover{color:#111827}.login-popup h3{color:#1a1c1c;margin:0 0 10px;font-size:21px;font-weight:800}.login-popup p{color:#6b7280;margin:0;font-size:14px;line-height:1.45}.forgot-popup{background:#fff;border-radius:9px;width:100%;max-width:350px;padding:34px 26px 28px;position:relative;box-shadow:0 18px 45px #0f172a47}.forgot-popup h3{text-align:center;color:#334155;margin:0 0 14px;font-size:26px;font-weight:800}.forgot-popup p{text-align:center;color:#4b5563;margin:0 0 20px;font-size:14px}.forgot-popup .form-group{margin-bottom:18px}.forgot-popup input{border:1px solid #cfd8e3;border-radius:6px;outline:none;width:100%;height:52px;padding:0 14px;font-size:16px}.forgot-actions{gap:12px;display:flex}.forgot-secondary-button,.forgot-confirm-button{cursor:pointer;border:none;border-radius:5px;flex:1;height:42px;font-size:14px;font-weight:700}.forgot-secondary-button{color:#475569;background:#f1f5f9}.forgot-confirm-button{color:#fff;background:#005894}.mobile-shell{background:#7f7f7f;justify-content:center;align-items:flex-start;min-height:100vh;padding:12px 0;display:flex}.mobile-shell__device{background:#f5f5f5;width:375px;height:812px;overflow:hidden}.mobile-shell__screen{background:#f5f5f5;height:812px;position:relative;overflow:hidden}.mobile-shell__content{height:100%;padding-bottom:78px;overflow:hidden auto}.mobile-shell__bottom{z-index:100;background:#fff;height:78px;position:absolute;bottom:0;left:0;right:0}.mobile-shell__content{scrollbar-width:none;-ms-overflow-style:none;height:100%;padding-bottom:78px;overflow:hidden auto}.mobile-shell__content::-webkit-scrollbar{display:none}.voucher-popup-overlay{z-index:9999;background:#0f172a8c;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.voucher-popup{border-radius:16px;width:100%;max-width:340px;padding:24px 20px;animation:.2s popupFadeIn;position:relative;box-shadow:0 18px 45px #0f172a47}.voucher-popup--valid{color:#166534;background:#ecfdf3;border:2px solid #86efac}.voucher-popup--invalid{color:#991b1b;background:#fee2e2;border:2px solid #fca5a5}.voucher-popup-close{width:28px;height:28px;color:inherit;cursor:pointer;background:0 0;border:none;font-size:24px;font-weight:800;line-height:1;position:absolute;top:10px;right:12px}.voucher-popup-close:hover{opacity:.75}.voucher-popup-icon{justify-content:center;align-items:center;margin-bottom:12px;display:flex}.voucher-popup--valid .voucher-popup-icon svg{color:#16a34a}.voucher-popup--invalid .voucher-popup-icon svg{color:#dc2626}.voucher-popup h3{text-align:center;margin:0;font-size:20px;font-weight:800}.voucher-popup-desc{text-align:center;margin:10px 0 18px;font-size:14px;line-height:1.5}.voucher-popup-info{background:#ffffffc7;border-radius:12px;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:18px;padding:14px;display:grid}.voucher-popup-info-item{flex-direction:column;gap:4px;min-width:0;display:flex}.voucher-popup-info-item--full{grid-column:1/-1}.voucher-popup-info div{flex-direction:column;gap:4px;display:flex}.voucher-popup-info span{text-transform:uppercase;opacity:.75;font-size:11px;font-weight:800}.voucher-popup-info strong{word-break:break-word;font-size:14px;font-weight:800;line-height:1.4}.voucher-popup-primary{color:#fff;cursor:pointer;background:#16a34a;border:none;border-radius:8px;width:100%;height:48px;font-size:15px;font-weight:800;transition:all .15s}.voucher-popup-primary:hover{background:#15803d}.voucher-popup-primary:active{transform:scale(.97)}.voucher-popup-link{cursor:pointer;width:100%;color:inherit;background:0 0;border:none;margin-top:10px;font-size:14px;font-weight:700}.voucher-popup-link:hover{text-decoration:underline}@keyframes popupFadeIn{0%{opacity:0;transform:translateY(8px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.vdv{background:#f4f6f8;flex-direction:column;height:100%;display:flex;overflow:hidden}.vdv__header{background:#fff;border-bottom:1px solid #e8ecf0;flex-shrink:0;align-items:center;gap:8px;padding:16px;display:flex}.vdv__back{cursor:pointer;color:#1a56db;background:0 0;border:none;align-items:center;padding:4px;display:flex}.vdv__title{color:#1a56db;flex:1;font-size:17px;font-weight:600}.vdv__logout{cursor:pointer;color:#6b7280;background:0 0;border:none;align-items:center;padding:4px;display:flex}.vdv__body{scrollbar-width:none;flex-direction:column;flex:1;align-items:center;gap:12px;padding:24px 16px;display:flex;overflow-y:auto}.vdv__body::-webkit-scrollbar{display:none}.vdv__status-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:72px;min-width:72px;height:72px;min-height:72px;margin-bottom:4px;display:flex}.vdv__status-icon--valid{background:#22c55e;box-shadow:0 0 0 12px #22c55e26}.vdv__status-icon--invalid{background:#ef4444;box-shadow:0 0 0 12px #ef44441f}.vdv__status-title{color:#111827;text-align:center;margin:0;font-size:20px;font-weight:700}.vdv__badge{letter-spacing:.3px;border-radius:20px;align-items:center;padding:4px 14px;font-size:13px;font-weight:600;display:inline-flex}.vdv__badge--valid{color:#16a34a;background:#dcfce7;border:1px solid #bbf7d0}.vdv__badge--used,.vdv__badge--invalid{color:#fff;background:#ef4444}.vdv__used-info{color:#6b7280;text-align:center;margin:0;font-size:13px;line-height:1.6}.vdv__card{background:#fff;border-radius:12px;width:100%;padding:16px;box-shadow:0 1px 4px #00000012}.vdv__field{flex-direction:column;gap:4px;padding:8px 0;display:flex}.vdv__field--row{flex-direction:row;justify-content:space-between;align-items:center;gap:12px}.vdv__field--row>div{flex-direction:column;gap:4px;min-width:0;display:flex}.vdv__label{color:#9ca3af;text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.vdv__value{color:#111827;font-size:14px;font-weight:500}.vdv__code{color:#374151;letter-spacing:1px;font-size:18px;font-weight:700}.vdv__grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.vdv__grid .vdv__field{background:#f3f3f3;border-radius:8px;padding:10px 12px}.vdv__divider{background:#f3f4f6;height:1px;margin:4px 0}.vdv__image-wrap{border-radius:8px;margin-top:12px;overflow:hidden}.vdv__image{object-fit:contain;width:100%;height:auto;display:block}.vdv__copy{cursor:pointer;color:#6b7280;background:#f3f4f6;border:none;border-radius:8px;flex-shrink:0;align-items:center;padding:8px;transition:background .2s,color .2s;display:flex}.vdv__copy--done{color:#16a34a;background:#dcfce7}.vdv__code-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;flex-direction:column;align-items:center;gap:8px;width:100%;padding:16px;display:flex}.vdv__invalid-code{color:#ef4444;letter-spacing:1px;word-break:break-all;text-align:center;font-size:20px;font-weight:700}.vdv__error-msg{color:#6b7280;text-align:center;margin:0;font-size:14px;line-height:1.5}.vdv__btn-scan-again{color:#1a56db;cursor:pointer;background:#fff;border:1.5px solid #1a56db;border-radius:10px;justify-content:center;align-items:center;gap:8px;width:100%;padding:12px;font-size:15px;font-weight:600;display:flex}.vdv__footer{background:#fff;border-top:1px solid #e8ecf0;flex-shrink:0;padding:16px}.vdv__btn-confirm{color:#fff;cursor:pointer;background:#15803d;border:none;border-radius:10px;width:100%;padding:14px;font-size:16px;font-weight:600}.vdv__btn-confirm:disabled{opacity:.6;cursor:not-allowed}.vdv__info-note{color:#3b82f6;background:#eff6ff;border-radius:8px;gap:8px;width:100%;padding:12px;font-size:12px;line-height:1.5;display:flex}.vdv__info-icon{flex-shrink:0;margin-top:1px;font-size:14px}.scanner-page{background:#fff;min-height:812px;padding-bottom:78px;font-family:Inter,Arial,sans-serif;position:relative}.scanner-header{border-bottom:1px solid #d8dee8;justify-content:space-between;align-items:center;height:86px;padding:16px 18px;display:flex}.scanner-user{align-items:center;gap:10px;display:flex}.scanner-avatar{color:#fff;background:linear-gradient(135deg,#005894,#0ea5e9);border-radius:50%;justify-content:center;align-items:center;width:38px;height:38px;font-size:13px;font-weight:800;display:flex}.scanner-user p{color:#7b8491;margin:0;font-size:10px;font-weight:500}.scanner-user h2{color:#1a1c1c;margin:2px 0 0;font-size:14px;font-weight:800}.logout-button{color:#374151;cursor:pointer;background:0 0;border:none;padding:6px}.qr-section{padding:22px 16px 0}.qr-preview{background:radial-gradient(circle,#3f3f3f 0%,#181818 65%);border-radius:8px;justify-content:center;align-items:center;height:300px;display:flex;overflow:hidden;box-shadow:0 8px 18px #0f172a2e}.qr-frame{justify-content:center;align-items:center;width:220px;height:220px;display:flex;position:relative}.corner{border-color:#005894;width:54px;height:54px;position:absolute}.corner-top-left{border-top:3px solid #005894;border-left:3px solid #005894;top:0;left:0}.corner-top-right{border-top:3px solid #005894;border-right:3px solid #005894;top:0;right:0}.corner-bottom-left{border-bottom:3px solid #005894;border-left:3px solid #005894;bottom:0;left:0}.corner-bottom-right{border-bottom:3px solid #005894;border-right:3px solid #005894;bottom:0;right:0}.phone-mock{background:#111827;border:8px solid #111827;border-radius:22px;width:106px;height:190px;position:relative;box-shadow:0 8px 22px #00000073}.phone-notch{background:#1f2937;border-radius:999px;width:42px;height:5px;margin:5px auto}.phone-screen{background:linear-gradient(135deg,#c7c7c7,#6b7280);border-radius:4px;justify-content:center;align-items:center;height:145px;margin:0 5px;display:flex}.ticket-card{background:#fff;border-radius:3px;width:58px;height:34px;transform:rotate(18deg)}.phone-button{background:#d1d5db;border-radius:50%;width:18px;height:18px;margin:6px auto 0}.qr-guide{text-align:center;color:#4b5563;margin:25px 0 0;font-size:15px}.divider{align-items:center;gap:18px;padding:28px 16px 22px;display:flex}.divider span{background:#cfd8e3;flex:1;height:1px}.divider p{color:#7b8491;margin:0;font-size:13px;font-weight:800}.manual-section{padding:0 16px}.manual-section label{color:#005894;margin-bottom:8px;font-size:13px;font-weight:800;display:block}.serial-input-wrapper{border:1px solid #cfd8e3;border-radius:7px;align-items:center;height:52px;padding:0 14px;display:flex}.serial-input-wrapper input{color:#111827;border:none;outline:none;flex:1;font-size:15px}.serial-input-wrapper input::placeholder{color:#8b95a5}.serial-input-wrapper svg{color:#4b5563}.verify-button{color:#fff;cursor:pointer;background:#005894;border:none;border-radius:6px;justify-content:center;align-items:center;gap:8px;width:100%;height:54px;margin-top:14px;font-size:18px;font-weight:800;transition:transform .12s,box-shadow .12s,opacity .12s;display:flex;box-shadow:0 6px 14px #00589442}.verify-button:hover{opacity:.95}.verify-button:active{transform:scale(.95);box-shadow:0 2px 6px #00589433}.scanner-video{object-fit:cover;border-radius:12px;width:100%;height:100%}.bottom-nav{background:#fff;border-top:1px solid #d8dee8;justify-content:space-around;align-items:center;width:100%;height:78px;display:flex}.bottom-nav-item{color:#6b7280;cursor:pointer;background:0 0;border:none;border-radius:999px;flex-direction:column;justify-content:center;align-items:center;gap:4px;min-width:72px;height:48px;font-size:11px;font-weight:700;transition:background .18s,color .18s,transform .12s;display:flex}.bottom-nav-item:hover{background:#f1f5f9}.bottom-nav-item:active{transform:scale(.94)}.bottom-nav-item.active{color:#0a7d38;background:#98fb98}.bottom-nav-item svg{width:20px;height:20px}.history-page{background:#f7f7f7;min-height:812px;padding:0 16px 96px;font-family:Inter,Arial,sans-serif}.history-header{align-items:center;gap:13px;height:56px;display:flex}.history-menu-button{color:#364152;cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;width:26px;height:26px;padding:0;display:flex}.history-header h1{color:#005894;margin:0;font-size:19px;font-weight:800;line-height:1}.history-summary-card{background:#fff;border:1px solid #cfd8e3;border-radius:9px;height:92px;padding:18px 18px 14px;box-shadow:0 1px 2px #0f172a08}.history-summary-card p{color:#6b7280;letter-spacing:.35px;margin:0 0 10px;font-size:10px;font-weight:800;line-height:1}.history-summary-card strong{color:#005894;font-size:26px;font-weight:900;line-height:1;display:block}.history-search{background:#fff;border:1px solid #cfd8e3;border-radius:7px;align-items:center;gap:10px;height:52px;margin-top:18px;padding:0 13px;display:flex}.history-search-icon{color:#6b7280;margin-top:-2px;font-size:26px;line-height:1;transform:rotate(-20deg)}.history-search input{color:#111827;background:0 0;border:none;outline:none;flex:1;font-size:14px;font-weight:500}.history-search input::placeholder{color:#8b95a5}.history-section-title{color:#6b7280;letter-spacing:.35px;margin:20px 0 11px;font-size:11px;font-weight:900}.history-list{flex-direction:column;gap:14px;display:flex}.history-card{background:#fff;border:1px solid #cfd8e3;border-radius:10px;align-items:flex-start;gap:16px;min-height:100px;padding:18px 16px;display:flex}.history-status-icon{color:#159447;background:#8df38f;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;display:flex}.history-card-content{flex:1;min-width:0}.history-card-content h2{color:#363b44;white-space:normal;overflow-wrap:anywhere;margin:0 0 6px;font-size:16px;font-weight:700;line-height:1.35}.history-card-content strong{color:#005894;font-size:13px;font-weight:900;line-height:1.15;display:block}.history-arrow{color:#c2c8d1;flex-shrink:0}.history-card{cursor:pointer}.history-card:active{transform:scale(.99)}.history-pagination{color:#6b7280;justify-content:flex-end;align-items:center;gap:8px;margin-top:16px;padding:8px 0;font-size:13px;display:flex}.pagination-label{font-weight:500}.pagination-size-select{color:#364152;cursor:pointer;background:#fff;border:1px solid #cfd8e3;border-radius:5px;outline:none;padding:3px 6px;font-size:13px;font-weight:600}.pagination-range{color:#364152;margin:0 4px;font-weight:500}.pagination-arrows{gap:4px;display:flex}.pagination-arrow{color:#364152;cursor:pointer;background:#fff;border:1px solid #cfd8e3;border-radius:5px;justify-content:center;align-items:center;width:28px;height:28px;padding:0;font-size:16px;font-weight:700;line-height:1;display:flex}.pagination-arrow:disabled{color:#c2c8d1;cursor:not-allowed;background:#f7f7f7}
