:root{--red-primary:#b91c1c;--red-dark:#7f1d1d;--sans:"Segoe UI", system-ui, -apple-system, Roboto, sans-serif;--touch-min:44px;--page-pad-x:clamp(.75rem, 4vw, 1.5rem);--page-pad-y:clamp(1rem, 3vw, 2rem);font-family:var(--sans);color:#292524;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-weight:400;line-height:1.5}*,:before,:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%;overflow-x:hidden}body{min-width:320px;margin:0;overflow-x:hidden}#root{min-height:100dvh}h1,h2,h3{font-family:var(--sans)}button,input,select,textarea{font-family:inherit}button{-webkit-tap-highlight-color:transparent}fieldset{min-width:0}legend{padding:0}img{max-width:100%;height:auto}.app{flex-direction:column;min-height:100svh;display:flex;position:relative}.app:before{content:"";z-index:-2;background:url(/trongdong.png) 50%/cover no-repeat;position:fixed;inset:0}.app:after{content:"";z-index:-1;background:linear-gradient(#ffffffe0 0%,#fffcf8eb 45%,#fffaf5f0 100%);position:fixed;inset:0}.app-header{color:#fff;z-index:10;background:linear-gradient(135deg,#b91c1c 0%,#991b1b 50%,#7f1d1d 100%);position:sticky;top:0;box-shadow:0 4px 20px #7f1d1d59}.app-header__inner{max-width:1100px;padding:1rem var(--page-pad-x);padding-top:max(1rem, env(safe-area-inset-top));align-items:center;gap:1.25rem;margin:0 auto;display:flex}.app-header__logo{object-fit:contain;filter:drop-shadow(0 2px 4px #0003);flex-shrink:0;width:72px;height:72px}.app-header__text{text-align:left;min-width:0}.app-header__eyebrow{opacity:.9;letter-spacing:.04em;text-transform:uppercase;margin:0 0 .25rem;font-size:.875rem;font-weight:500}.app-header__title{text-transform:uppercase;letter-spacing:.02em;margin:0;font-size:clamp(.95rem,2.2vw,1.35rem);font-weight:700;line-height:1.28}.app-header__title-full{white-space:nowrap;display:block}.app-header__title-stack{display:none}.app-header__title-main,.app-header__title-sub{display:block}.app-main{width:100%;max-width:720px;padding:var(--page-pad-y) var(--page-pad-x) max(2rem, env(safe-area-inset-bottom));box-sizing:border-box;flex:1;margin:0 auto}.queue-card__head{margin-bottom:1.5rem}.queue-card__title-row{justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.5rem;display:flex}.queue-card__title-row .queue-card__title{flex:1;min-width:0;margin:0;line-height:1.3}.queue-card__head .queue-card__subtitle{margin:0}.text-link{color:#b91c1c;cursor:pointer;text-underline-offset:2px;white-space:nowrap;background:0 0;border:none;flex-shrink:0;align-self:center;align-items:center;padding:0;font-family:inherit;font-size:.9rem;font-weight:500;line-height:1.3;text-decoration:underline;display:inline-flex}.text-link:hover{color:#7f1d1d}.text-link:focus-visible{outline-offset:2px;border-radius:2px;outline:2px solid #b91c1c}.queue-card{background:#fff;border-radius:16px;padding:1.75rem 2rem;box-shadow:0 4px 24px #00000014,0 0 0 1px #b91c1c14}.queue-card__title{color:#7f1d1d;margin:0 0 .5rem;font-size:1.5rem;font-weight:700}.queue-card__subtitle{color:#57534e;font-size:.95rem}.unknown-tenant__text{color:#57534e;margin:0 0 1rem;line-height:1.6}.unknown-tenant__list{flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.unknown-tenant__link{color:#b91c1c;background:#b91c1c0f;border:1px solid #b91c1c33;border-radius:10px;padding:.65rem 1rem;font-weight:600;text-decoration:none;display:inline-block}.unknown-tenant__link:hover{background:#b91c1c1f}.queue-card__divider{text-align:center;color:#a8a29e;margin:1rem 0 .5rem;font-size:.85rem}.queue-form__hint{color:#57534e;margin:0;font-size:.9rem}.queue-form__select{color:#44403c;cursor:pointer;appearance:auto;background:#fff;border:1px solid #d6d3d1;border-radius:10px;width:100%;padding:.75rem 1rem;font-family:inherit;font-size:1rem}.queue-form__select:focus{border-color:#b91c1c;outline:none;box-shadow:0 0 0 3px #b91c1c26}.queue-form__select:disabled{opacity:.6;cursor:not-allowed}.counter-status{background:#fafaf9;border:1px solid #e7e5e4;border-radius:12px;padding:1rem 1.15rem}.counter-status__select-wrap{flex-direction:column;gap:.35rem;display:flex}.counter-status__branch{color:#78716c;margin:0 0 .75rem;font-size:.85rem}.counter-status__grid{grid-template-columns:repeat(3,1fr);gap:.5rem;display:grid}.counter-status__item{background:#fff;border-left:3px solid #b91c1c;border-radius:8px;flex-direction:column;align-items:center;gap:.2rem;min-width:0;padding:.65rem .5rem;display:flex}.counter-status__item--highlight{background:#b91c1c0a;border-left-color:#dc2626}.counter-status__unit{color:#a8a29e;font-size:.7rem}.counter-status__value--ticket{letter-spacing:.04em;font-size:1.5rem}.counter-status__label{color:#57534e;text-align:center;font-size:.75rem;line-height:1.3}.counter-status__value{color:#b91c1c;font-variant-numeric:tabular-nums;font-size:1.35rem;font-weight:700}.counter-status__asof{color:#a8a29e;text-align:center;margin:.75rem 0 0;font-size:.75rem}.counter-status__hint,.counter-status__error{margin:0;font-size:.9rem}.counter-status__error{color:#991b1b}.service-option__name{font-weight:600;display:block}.service-option__meta{color:#78716c;margin-top:.25rem;font-size:.75rem;font-weight:400;display:block}.service-option input:disabled+.service-option__box{opacity:.55;cursor:not-allowed}.alert{border-radius:10px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.9rem}.alert--error{color:#991b1b;background:#fef2f2;border:1px solid #fecaca}.alert--dev{color:#92400e;background:#fffbeb;border:1px solid #fde68a}.btn-secondary{min-height:var(--touch-min);color:#44403c;cursor:pointer;background:#fafaf9;border:1px solid #d6d3d1;border-radius:10px;padding:.75rem 1.25rem;font-family:inherit;font-size:1rem;font-weight:600}.btn-secondary:hover{background:#f5f5f4}.btn-link{color:#b91c1c;cursor:pointer;text-underline-offset:2px;background:0 0;border:none;width:100%;margin-top:.5rem;padding:.5rem;font-family:inherit;font-size:.95rem;font-weight:500;text-decoration:underline;display:block}.btn-link:hover{color:#7f1d1d}.btn-danger{min-height:var(--touch-min);color:#fff;cursor:pointer;background:#78716c;border:none;border-radius:10px;padding:.75rem 1rem;font-family:inherit;font-size:.95rem;font-weight:600}.ticket-panel__actions .btn-primary,.ticket-panel__actions .btn-secondary,.ticket-panel__actions .btn-danger{flex:100%;min-width:min(100%,280px)}.btn-danger:hover{background:#57534e}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.ticket-panel{flex-direction:column;align-items:center;gap:.75rem;display:flex}.ticket-panel__summary{background:#fafaf9;border:1px solid #e7e5e4;border-radius:12px;grid-template-columns:1fr 1fr;gap:.55rem .75rem;width:100%;margin:0;padding:.75rem .85rem;display:grid}.ticket-panel__summary>div{flex-direction:column;gap:.15rem;min-width:0;display:flex}.ticket-panel__summary-item--wide{grid-column:1/-1}.ticket-panel__summary dt{color:#78716c;margin:0;font-size:.75rem;line-height:1.3}.ticket-panel__summary dd{color:#44403c;word-break:break-word;margin:0;font-size:.88rem;font-weight:600;line-height:1.35}.ticket-panel__header{text-align:center;width:100%}.status-badge{border-radius:999px;padding:.35rem .85rem;font-size:.85rem;font-weight:600;display:inline-block}.status-badge--waiting_checkin{color:#92400e;background:#fef3c7}.status-badge--waiting,.status-badge--called,.status-badge--serving{color:#1e40af;background:#dbeafe}.status-badge--called{color:#92400e;background:#fef3c7;animation:1.5s ease-in-out infinite status-pulse}@keyframes status-pulse{0%,to{box-shadow:0 0 #d9770659}50%{box-shadow:0 0 0 6px #d9770600}}.ticket-qr-card{background:#fff;border:1px solid #b91c1c1f;border-radius:14px;flex-direction:column;align-items:center;gap:.75rem;width:100%;max-width:min(100%,320px);margin:0 auto;padding:1rem;display:flex;box-shadow:0 4px 16px #7f1d1d0f}.ticket-qr-card--compact{gap:.65rem;width:100%;max-width:none;padding:.85rem 1rem 1rem}.ticket-qr-card__qr-wrap{background:#fff;border:1px solid #f5f5f4;border-radius:12px;width:min(148px,38vw);padding:.5rem;box-shadow:inset 0 0 0 1px #b91c1c0a}.ticket-qr-card__img{aspect-ratio:1;object-fit:contain;border-radius:6px;width:100%;height:auto;display:block}.ticket-qr-card__placeholder{aspect-ratio:1;color:#d6d3d1;background:#fafaf9;border-radius:6px;justify-content:center;align-items:center;width:100%;font-size:1.5rem;display:flex}.ticket-qr-card__foot{text-align:center;width:100%}.ticket-qr-card__eyebrow{letter-spacing:.04em;text-transform:uppercase;color:#a8a29e;margin:0 0 .25rem;font-size:.75rem;font-weight:600}.ticket-qr-card__code{letter-spacing:.02em;color:#78716c;word-break:break-word;overflow-wrap:anywhere;margin:0;font-size:.8rem;font-weight:600;line-height:1.45}.btn-download-ticket{width:100%;min-height:var(--touch-min);color:#fff;cursor:pointer;background:linear-gradient(135deg,#dc2626 0%,#b91c1c 100%);border:none;border-radius:10px;padding:.75rem 1rem;font-family:inherit;font-size:.95rem;font-weight:700;transition:transform .15s,box-shadow .2s,opacity .2s;box-shadow:0 3px 12px #b91c1c40}.btn-download-ticket:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 5px 16px #b91c1c52}.btn-download-ticket:disabled{opacity:.6;cursor:not-allowed;transform:none}.ticket-qr-card__error{color:#991b1b;text-align:center;margin:0;font-size:.82rem;line-height:1.4}.queue-card--ticket .queue-card__head{margin-bottom:.65rem}.queue-card--ticket .queue-card__title{font-size:1.15rem}.ticket-countdown{text-align:center;background:#fffbeb;border:1px solid #fde68a;border-radius:10px;width:100%;padding:.75rem 1rem}.ticket-countdown--expired{background:#fef2f2;border-color:#fecaca}.ticket-countdown__label{color:#78716c;margin-bottom:.25rem;font-size:.8rem;display:block}.ticket-countdown__value{font-variant-numeric:tabular-nums;color:#92400e;font-size:1.5rem;font-weight:700;display:block}.ticket-countdown--expired .ticket-countdown__value{color:#991b1b;font-size:1rem}.ticket-panel__code{letter-spacing:.04em;color:#78716c;text-align:center;word-break:break-all;margin:0;font-size:1rem;font-weight:700}.status-badge--done{color:#166534;background:#dcfce7}.status-badge--cancelled,.status-badge--expired,.status-badge--missed{color:#57534e;background:#f5f5f4}.ticket-details{gap:.65rem;width:100%;margin:0;display:grid}.ticket-details>div{border-bottom:1px solid #f5f5f4;justify-content:space-between;gap:1rem;padding:.5rem 0;display:flex}.ticket-details dt{color:#78716c;margin:0;font-size:.85rem}.ticket-details dd{color:#44403c;text-align:right;margin:0;font-weight:600}.ticket-details__queue-num{font-size:1.25rem;color:#b91c1c!important}.ticket-panel__note{color:#57534e;text-align:center;margin:0;font-size:.9rem;line-height:1.5}.ticket-panel__actions{flex-wrap:wrap;justify-content:center;gap:.75rem;width:100%;display:flex}.queue-form{flex-direction:column;gap:1.25rem;display:flex}.queue-form__group{border:none;min-width:0;margin:0;padding:0}.queue-form__label{color:#44403c;margin-bottom:.5rem;font-size:.875rem;font-weight:600;display:block}.queue-form__row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.queue-form__field{flex-direction:column;gap:.35rem;display:flex}.queue-form__field input,.queue-form__select{width:100%;min-height:var(--touch-min)}.queue-form__field input{border:1px solid #d6d3d1;border-radius:10px;padding:.75rem 1rem;font-family:inherit;font-size:1rem;transition:border-color .2s,box-shadow .2s}.queue-form--otp{gap:1.5rem}.otp-step{text-align:center;flex-direction:column;align-items:center;padding:.5rem 0 .25rem;display:flex}.otp-step__message{color:#44403c;margin:0 0 .35rem;font-size:.95rem;line-height:1.5}.otp-step__message strong{color:#7f1d1d;font-weight:700}.otp-step__expires{color:#78716c;margin:0 0 1.25rem;font-size:.85rem}.otp-step__field{width:100%;max-width:360px}.otp-step__field .queue-form__label{text-align:center;margin-bottom:.75rem}.otp-step .alert--dev{width:100%;max-width:360px;margin-bottom:1rem}.otp-input{width:100%}.otp-input__legend{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.otp-input__cells{justify-content:center;gap:clamp(.4rem,2.5vw,.65rem);display:flex}.otp-input__cell{font-variant-numeric:tabular-nums;text-align:center;color:#7f1d1d;caret-color:#b91c1c;background:#fff;border:2px solid #e7e5e4;border-radius:12px;width:clamp(2.75rem,12vw,3.25rem);height:clamp(3.25rem,14vw,3.75rem);padding:0;font-size:clamp(1.35rem,5vw,1.6rem);font-weight:700;transition:border-color .2s,box-shadow .2s,background .2s,transform .15s;box-shadow:0 1px 2px #0000000a}.otp-input__cell::placeholder{color:#0000}.otp-input__cell:hover:not(:disabled){border-color:#d6d3d1}.otp-input__cell:focus{background:#fff;border-color:#b91c1c;outline:none;transform:translateY(-1px);box-shadow:0 0 0 4px #b91c1c1f,0 4px 12px #b91c1c14}.otp-input__cell--filled{background:#b91c1c0a;border-color:#b91c1c59}.otp-input__cell--filled:focus{background:#fff}.otp-input__cell:disabled{opacity:.55;cursor:not-allowed}.queue-form__field input:focus{border-color:#b91c1c;outline:none;box-shadow:0 0 0 3px #b91c1c26}.queue-form__field input::placeholder{color:#a8a29e}.service-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.65rem;display:grid}.service-option{cursor:pointer}.service-option input{opacity:0;pointer-events:none;position:absolute}.service-option__box{color:#44403c;text-align:center;border:2px solid #e7e5e4;border-radius:10px;padding:.75rem 1rem;font-size:.9rem;font-weight:500;transition:border-color .2s,background .2s,color .2s;display:block}.service-option input:checked+.service-option__box{color:#7f1d1d;background:#b91c1c0f;border-color:#b91c1c}.service-option input:focus-visible+.service-option__box{outline-offset:2px;outline:2px solid #b91c1c}.service-option:hover .service-option__box{border-color:#d6d3d1}.btn-primary{min-height:var(--touch-min);color:#fff;cursor:pointer;text-transform:uppercase;letter-spacing:.03em;background:linear-gradient(135deg,#dc2626 0%,#b91c1c 100%);border:none;border-radius:12px;margin-top:.5rem;padding:.875rem 1.5rem;font-family:inherit;font-size:1.05rem;font-weight:700;transition:transform .15s,box-shadow .2s;box-shadow:0 4px 14px #b91c1c59}.queue-form .btn-primary,.queue-form .btn-secondary{width:100%}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #b91c1c66}.btn-primary:active{transform:translateY(0)}.btn-primary:focus-visible{outline-offset:2px;outline:3px solid #b91c1c66}.modal-overlay{z-index:100;background:#1c191773;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:16px;width:100%;max-width:440px;max-height:min(90vh,520px);overflow:auto;box-shadow:0 20px 50px #0003}.modal__header{justify-content:space-between;align-items:center;gap:1rem;padding:1.25rem 1.5rem 0;display:flex}.modal__title{color:#7f1d1d;margin:0;font-size:1.25rem;font-weight:700}.modal__close{color:#78716c;cursor:pointer;background:#f5f5f4;border:none;border-radius:8px;width:2.25rem;height:2.25rem;padding:0;font-size:1.5rem;line-height:1}.modal__close:hover{color:#44403c;background:#e7e5e4}.modal__body{padding:1rem 1.5rem 1.25rem}.modal__footer{padding:0 1.5rem 1.5rem}.modal__footer .btn-primary{width:100%;margin-top:0}.guide-steps{color:#57534e;margin:0 0 1.25rem;padding-left:1.25rem;font-size:.95rem;line-height:1.75}.guide-note{background:#fafaf9;border-left:3px solid #b91c1c;border-radius:10px;padding:1rem}.guide-note__title{text-transform:uppercase;letter-spacing:.05em;color:#a8a29e;margin:0 0 .5rem;font-size:.8rem;font-weight:600}.guide-note p{color:#57534e;margin:0;font-size:.9rem;line-height:1.6}.app-footer{text-align:center;color:#78716c;background:#ffffffbf;border-top:1px solid #b91c1c1f;padding:1rem 1.5rem;font-size:.85rem}.app-footer p{margin:0}@media (width<=640px){.app-header__inner{padding:.75rem var(--page-pad-x);padding-top:max(.75rem, env(safe-area-inset-top));gap:.65rem}.app-header__logo{width:44px;height:44px}.app-header__eyebrow{letter-spacing:.03em;font-size:.7rem}.app-header__title{letter-spacing:.018em;font-size:clamp(.78rem,3.4vw,1rem);line-height:1.28}.app-header__title-full{display:none}.app-header__title-stack{flex-direction:column;gap:.15rem;display:flex}.app-main{padding-bottom:max(1.5rem, env(safe-area-inset-bottom))}.queue-card{padding:1.15rem var(--page-pad-x);border-radius:12px}.queue-card__head{margin-bottom:1.15rem}.queue-card__title-row{flex-wrap:nowrap;gap:.5rem}.queue-card__title{font-size:1.2rem;line-height:1.3}.queue-card__subtitle{font-size:.875rem;line-height:1.5}.text-link{margin:-.35rem -.15rem;padding:.35rem .15rem;font-size:.85rem;line-height:1.3}.queue-form{gap:1rem}.queue-form__row{grid-template-columns:1fr;gap:.85rem}.queue-form__field input,.queue-form__select{font-size:16px}.otp-input__cells{gap:.35rem}.otp-input__cell{border-radius:10px;width:2.65rem;height:3.15rem;font-size:1.4rem}.counter-status{padding:.85rem}.counter-status__grid{grid-template-columns:1fr;gap:.4rem}.counter-status__item{flex-direction:row;justify-content:space-between;align-items:center;gap:.75rem;padding:.75rem .85rem}.counter-status__label{text-align:left;flex:1;font-size:.8rem}.counter-status__value,.counter-status__value--ticket{flex-shrink:0;font-size:1.25rem}.counter-status__unit{display:none}.counter-status__item--highlight{order:3}.status-badge{text-align:center;max-width:100%;padding:.4rem .65rem;font-size:.78rem;line-height:1.35}.queue-card--ticket{padding-top:.85rem}.queue-card--ticket .queue-card__head{margin-bottom:.5rem}.ticket-panel{gap:.6rem}.ticket-countdown__value{font-size:1.25rem}.ticket-qr-card{border-radius:12px;max-width:none}.ticket-qr-card__qr-wrap{width:min(136px,34vw)}.ticket-details>div{flex-direction:column;align-items:flex-start;gap:.2rem;padding:.6rem 0}.ticket-details dd{text-align:left;word-break:break-word;width:100%}.ticket-panel__actions{flex-direction:column;align-items:stretch}.ticket-panel__actions .btn-danger,.ticket-panel__actions .btn-secondary{width:100%;min-width:0}.alert{padding:.65rem .85rem;font-size:.85rem}.modal-overlay{align-items:flex-end;padding:0}.modal{width:100%;max-width:none;max-height:min(88dvh,520px);padding-bottom:env(safe-area-inset-bottom);border-radius:16px 16px 0 0}.modal__header,.modal__body,.modal__footer{padding-left:var(--page-pad-x);padding-right:var(--page-pad-x)}.modal__footer{padding-bottom:max(1.25rem, env(safe-area-inset-bottom))}.app-footer{padding:.85rem var(--page-pad-x);padding-bottom:max(.85rem, env(safe-area-inset-bottom));font-size:.8rem}}@media (width<=380px){.counter-status__value--ticket{font-size:1.1rem}}
