@import"https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700;800&family=Inter:wght@400;500;600;700&display=swap";.app{max-width:480px;margin:0 auto;padding:var(--space-md);min-height:100dvh}@media(min-width:768px){.app{max-width:560px;padding:var(--space-xl)}}.customer-profile[data-v-cd3c2360]{background:var(--tnc-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.profile-row[data-v-cd3c2360]{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--tnc-gray-100)}.profile-row[data-v-cd3c2360]:last-child{border-bottom:none}.profile-label[data-v-cd3c2360]{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--tnc-gray-500);min-width:64px;padding-top:.35rem;flex-shrink:0}.profile-value-wrap[data-v-cd3c2360]{flex:1;display:flex;flex-direction:column;gap:var(--space-xs)}.profile-value[data-v-cd3c2360]{font-size:.9rem;font-weight:500;color:var(--tnc-dark);padding-top:.35rem}.profile-edit-group[data-v-cd3c2360]{display:flex;flex-direction:column;gap:var(--space-xs)}.profile-input[data-v-cd3c2360]{font-size:.9rem;padding:.4rem .6rem}.birthday-selects[data-v-cd3c2360]{display:flex;gap:var(--space-sm)}.profile-select[data-v-cd3c2360]{font-size:.85rem;padding:.4rem .5rem;flex:1}.profile-once-note[data-v-cd3c2360]{font-size:.72rem;color:var(--tnc-gray-400, var(--tnc-gray-500));margin:0;line-height:1.4}.profile-error[data-v-cd3c2360]{font-size:.75rem;color:var(--tnc-coral)}.stamp-card--completed[data-v-1ab63244]{border:2px solid var(--tnc-yellow)}.stamp-card--redeemed[data-v-1ab63244]{opacity:.55}.stamp-card-logo img[data-v-1ab63244]{width:40px;height:40px;object-fit:cover;display:block}.progress-reward[data-v-1ab63244]{color:var(--tnc-yellow);font-weight:600}.stamp-card-action[data-v-1ab63244]{margin-top:var(--space-sm);padding-top:var(--space-sm);border-top:1px solid var(--tnc-gray-100)}.customer-view[data-v-3ed64fff]{padding-bottom:72px}.page-header[data-v-3ed64fff]{padding:var(--space-xl) 0 var(--space-lg)}.header-main[data-v-3ed64fff]{display:flex;align-items:center;gap:var(--space-md)}.header-logo[data-v-3ed64fff]{width:72px;height:72px;flex-shrink:0}.header-logo img[data-v-3ed64fff]{width:72px;height:72px;object-fit:cover;display:block}.header-text[data-v-3ed64fff]{flex:1}.page-title[data-v-3ed64fff]{font-family:var(--font-display);font-size:1.5rem;font-weight:800;letter-spacing:-.02em}.page-subtitle[data-v-3ed64fff]{font-size:.85rem;color:var(--tnc-gray-500)}.header-qr[data-v-3ed64fff]{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0}.qr-label[data-v-3ed64fff]{font-size:.65rem;color:var(--tnc-gray-500);text-align:center;line-height:1.2}.daily-quote[data-v-3ed64fff]{display:flex;align-items:flex-start;gap:.35rem;padding:0 var(--space-xs) var(--space-md)}.quote-open[data-v-3ed64fff]{font-family:Georgia,Times New Roman,serif;font-size:2.5rem;line-height:1;color:var(--tnc-green);opacity:.5;flex-shrink:0;margin-top:-.25rem}.quote-text[data-v-3ed64fff]{font-family:Georgia,Times New Roman,serif;font-style:italic;font-size:.9rem;line-height:1.6;color:var(--tnc-gray-500);margin:0;padding-top:.3rem}.lookup-section[data-v-3ed64fff]{background:var(--tnc-white);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-sm);margin-bottom:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-md)}.profile-card[data-v-3ed64fff]{background:var(--tnc-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden;margin-bottom:var(--space-lg)}.profile-row[data-v-3ed64fff]{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--tnc-gray-100)}.profile-label[data-v-3ed64fff]{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--tnc-gray-500);min-width:64px;padding-top:.35rem;flex-shrink:0}.profile-value-wrap[data-v-3ed64fff]{flex:1;display:flex;flex-direction:column;gap:var(--space-xs)}.profile-row-inline[data-v-3ed64fff]{flex-direction:row;align-items:center;justify-content:space-between}.profile-value[data-v-3ed64fff]{font-size:.9rem;font-weight:500;color:var(--tnc-dark);padding-top:.35rem}.profile-row-inline .profile-value[data-v-3ed64fff]{padding-top:0}.profile-logout-btn[data-v-3ed64fff]{background:none;border:none;cursor:pointer;font-size:.75rem;font-weight:600;color:var(--tnc-gray-400, var(--tnc-gray-500));padding:0;font-family:var(--font-sans);flex-shrink:0}.profile-logout-btn[data-v-3ed64fff]:hover{color:var(--tnc-coral)}.profile-card[data-v-3ed64fff] .customer-profile{border-radius:0;box-shadow:none}.cards-list[data-v-3ed64fff]{display:flex;flex-direction:column;gap:var(--space-md);margin-top:var(--space-md)}.history-section[data-v-3ed64fff]{margin-top:var(--space-sm)}.history-empty[data-v-3ed64fff]{text-align:center;color:var(--tnc-gray-500);font-size:.875rem;padding:var(--space-2xl) 0}.history-list[data-v-3ed64fff]{list-style:none;padding:0;margin:0;display:flex;flex-direction:column}.history-item[data-v-3ed64fff]{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--tnc-white);border-bottom:1px solid var(--tnc-gray-100)}.history-item[data-v-3ed64fff]:first-child{border-radius:var(--radius-lg) var(--radius-lg) 0 0}.history-item[data-v-3ed64fff]:last-child{border-bottom:none;border-radius:0 0 var(--radius-lg) var(--radius-lg)}.history-item[data-v-3ed64fff]:only-child{border-radius:var(--radius-lg)}.history-dot[data-v-3ed64fff]{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:.3rem}.history-dot--stamp[data-v-3ed64fff]{background:var(--tnc-gray-300)}.history-dot--complete[data-v-3ed64fff]{background:var(--tnc-green)}.history-dot--redeem[data-v-3ed64fff]{background:var(--tnc-green-dark)}.history-body[data-v-3ed64fff]{flex:1;display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-sm)}.history-label[data-v-3ed64fff]{font-size:.875rem;font-weight:500;color:var(--tnc-dark)}.history-date[data-v-3ed64fff]{font-size:.75rem;color:var(--tnc-gray-500);white-space:nowrap;flex-shrink:0}.bottom-nav[data-v-3ed64fff]{position:fixed;bottom:0;left:0;right:0;display:flex;background:var(--tnc-white);border-top:1px solid var(--tnc-gray-100);padding-bottom:env(safe-area-inset-bottom);z-index:100}.nav-tab[data-v-3ed64fff]{flex:1;padding:.75rem .5rem;font-size:.82rem;font-weight:600;font-family:var(--font-sans);border:none;background:transparent;cursor:pointer;color:var(--tnc-gray-400, var(--tnc-gray-500));transition:color .15s;border-top:2px solid transparent}.nav-tab.active[data-v-3ed64fff]{color:var(--tnc-green-dark);border-top-color:var(--tnc-green-dark)}@media(min-width:768px){.header-logo[data-v-3ed64fff],.header-logo img[data-v-3ed64fff]{width:88px;height:88px}.page-title[data-v-3ed64fff]{font-size:1.75rem}}.pin-gate[data-v-ea8b30a4]{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-lg)}.pin-card[data-v-ea8b30a4]{width:100%;max-width:320px;display:flex;flex-direction:column;align-items:center;gap:var(--space-md);text-align:center}.pin-logo[data-v-ea8b30a4]{width:64px;height:64px}.pin-logo img[data-v-ea8b30a4]{width:64px;height:64px;object-fit:cover;display:block}.pin-title[data-v-ea8b30a4]{font-family:var(--font-display);font-size:1.35rem;font-weight:800;letter-spacing:-.02em;margin:0}.pin-subtitle[data-v-ea8b30a4]{font-size:.85rem;color:var(--tnc-gray-500);margin:0}.pin-field[data-v-ea8b30a4]{width:100%}.pin-input[data-v-ea8b30a4]{width:100%;text-align:center;font-size:1.5rem;font-family:var(--font-display);font-weight:700;letter-spacing:.25em;padding:.75rem;border:1.5px solid var(--tnc-gray-300);border-radius:var(--radius-md);background:var(--tnc-white);color:var(--tnc-dark);outline:none}.pin-input[data-v-ea8b30a4]:focus{border-color:var(--tnc-green);box-shadow:0 0 0 3px color-mix(in srgb,var(--tnc-green) 15%,transparent)}.pin-error[data-v-ea8b30a4]{width:100%}.pin-hint[data-v-ea8b30a4]{font-size:.75rem;color:var(--tnc-gray-300);margin:0}.pin-gate-loading[data-v-ea8b30a4]{min-height:100vh}.staff-view[data-v-bb1dff63]{padding-bottom:72px}.page-header[data-v-bb1dff63]{text-align:center;padding:var(--space-xl) 0 var(--space-lg)}.header-logo[data-v-bb1dff63]{width:56px;height:56px;margin:0 auto var(--space-sm)}.header-logo img[data-v-bb1dff63]{width:56px;height:56px;object-fit:cover;display:block}.page-title[data-v-bb1dff63]{font-family:var(--font-display);font-size:1.35rem;font-weight:800;letter-spacing:-.02em}.page-subtitle[data-v-bb1dff63]{font-size:.85rem;color:var(--tnc-gray-500)}.bottom-nav[data-v-bb1dff63]{position:fixed;bottom:0;left:0;right:0;display:flex;background:var(--tnc-white);border-top:1px solid var(--tnc-gray-100);padding-bottom:env(safe-area-inset-bottom);z-index:100}.nav-tab[data-v-bb1dff63]{flex:1;padding:.75rem .5rem;font-size:.82rem;font-weight:600;font-family:var(--font-sans);border:none;background:transparent;cursor:pointer;color:var(--tnc-gray-400, var(--tnc-gray-500));transition:color .15s;border-top:2px solid transparent}.nav-tab.active[data-v-bb1dff63]{color:var(--tnc-green-dark);border-top-color:var(--tnc-green-dark)}.form-card[data-v-bb1dff63]{background:var(--tnc-white);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-sm);margin-bottom:var(--space-md);display:flex;flex-direction:column;gap:var(--space-md)}.customer-panel[data-v-bb1dff63]{display:flex;flex-direction:column;gap:var(--space-md)}.customer-panel-header[data-v-bb1dff63]{display:flex;align-items:center;justify-content:space-between;background:var(--tnc-white);border-radius:var(--radius-lg);padding:var(--space-sm) var(--space-md);box-shadow:var(--shadow-sm)}.panel-phone[data-v-bb1dff63]{font-family:var(--font-display);font-weight:700;font-size:1rem;color:var(--tnc-dark)}.btn-link[data-v-bb1dff63]{background:none;border:none;cursor:pointer;color:var(--tnc-green-dark);font-size:.82rem;font-weight:600;padding:0;font-family:var(--font-sans)}.result-detail[data-v-bb1dff63]{font-size:.8rem;font-weight:400;margin-top:.15rem}.card-action-row[data-v-bb1dff63]{display:flex;align-items:center;gap:var(--space-md)}.card-action-row .btn[data-v-bb1dff63]{flex:1}.count-control[data-v-bb1dff63]{display:flex;align-items:center;gap:var(--space-md)}.count-btn[data-v-bb1dff63]{width:36px;height:36px;border-radius:var(--radius-full);border:1.5px solid var(--tnc-gray-300);background:var(--tnc-white);font-size:1.1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--tnc-dark);transition:all .15s}.count-btn[data-v-bb1dff63]:hover:not(:disabled){border-color:var(--tnc-green);color:var(--tnc-green)}.count-btn[data-v-bb1dff63]:disabled{opacity:.3;cursor:not-allowed}.count-value[data-v-bb1dff63]{font-size:1.2rem;font-weight:700;font-family:var(--font-display);min-width:1.5rem;text-align:center}.btn-ghost[data-v-bb1dff63]{background:none;border:none;cursor:pointer;color:var(--tnc-gray-500);font-size:.82rem;font-family:var(--font-sans);font-weight:500;text-align:center;padding:var(--space-xs) 0;width:100%}.btn-ghost[data-v-bb1dff63]:hover{color:var(--tnc-dark)}.filter-row[data-v-bb1dff63]{margin-bottom:var(--space-sm)}.filter-input[data-v-bb1dff63]{font-size:.875rem}.filter-loading[data-v-bb1dff63]{display:flex;justify-content:center;padding:var(--space-2xl) 0}.filter-spinner[data-v-bb1dff63]{display:block;width:22px;height:22px;border-width:2.5px;border-style:solid;border-color:var(--tnc-gray-200);border-top-color:var(--tnc-green);border-radius:50%;animation:spin-bb1dff63 .6s linear infinite}@keyframes spin-bb1dff63{to{transform:rotate(360deg)}}.customers-table-wrap[data-v-bb1dff63]{display:flex;flex-direction:column;gap:var(--space-md)}.customers-table[data-v-bb1dff63]{width:100%;border-collapse:collapse;background:var(--tnc-white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);font-size:.875rem}.customers-table thead tr[data-v-bb1dff63]{background:var(--tnc-gray-100)}.customers-table th[data-v-bb1dff63]{padding:.6rem .875rem;text-align:left;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--tnc-gray-500)}.customers-table td[data-v-bb1dff63]{padding:.75rem .875rem;border-top:1px solid var(--tnc-gray-100);vertical-align:middle}.customer-row[data-v-bb1dff63]{cursor:pointer;transition:background .12s}.customer-row[data-v-bb1dff63]:hover{background:var(--tnc-gray-50, #f9fafb)}.customer-row[data-v-bb1dff63]:active{background:var(--tnc-gray-100)}.col-phone[data-v-bb1dff63]{display:flex;flex-direction:column;gap:.1rem}.phone-num[data-v-bb1dff63]{font-weight:600;font-family:var(--font-display);color:var(--tnc-dark)}.customer-name[data-v-bb1dff63]{font-size:.75rem;color:var(--tnc-gray-500)}.col-stamps[data-v-bb1dff63]{white-space:nowrap}.stamp-progress[data-v-bb1dff63]{font-weight:700;font-family:var(--font-display);font-size:1rem;color:var(--tnc-green-dark)}.stamp-denom[data-v-bb1dff63]{font-weight:400;font-size:.8rem;color:var(--tnc-gray-300)}.col-rewards[data-v-bb1dff63]{white-space:nowrap}.rewards-none[data-v-bb1dff63]{color:var(--tnc-gray-300)}.rewards-logos[data-v-bb1dff63]{display:flex;gap:4px;align-items:center}.reward-logo-wrap[data-v-bb1dff63]{width:24px;height:24px;flex-shrink:0}.reward-logo-wrap img[data-v-bb1dff63]{width:24px;height:24px;object-fit:cover;display:block}.customers-loading[data-v-bb1dff63],.customers-empty[data-v-bb1dff63]{text-align:center;color:var(--tnc-gray-500);padding:var(--space-xl) 0;font-size:.9rem}.refresh-btn[data-v-bb1dff63]{width:auto;align-self:flex-end}@media(min-width:768px){.page-title[data-v-bb1dff63]{font-size:1.5rem}}:root{--tnc-green: #7AC143;--tnc-green-dark: #5A9A2F;--tnc-green-light: #E8F5D8;--tnc-yellow: #E8C840;--tnc-yellow-light: #FDF6D8;--tnc-coral: #C85A3A;--tnc-coral-light: #FAEAE4;--tnc-sky: #4AADD4;--tnc-sky-light: #DFF0F8;--tnc-dark: #2A2A2A;--tnc-gray-700: #4A4A4A;--tnc-gray-500: #7A7A7A;--tnc-gray-300: #B8B8B8;--tnc-gray-100: #E8E8E8;--tnc-beige: #F5F0EB;--tnc-cream: #FAF8F5;--tnc-white: #FFFFFF;--tnc-success: var(--tnc-green);--tnc-warning: var(--tnc-yellow);--tnc-error: var(--tnc-coral);--tnc-info: var(--tnc-sky);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-display: "DM Sans", var(--font-sans);--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(42, 42, 42, .06);--shadow-md: 0 2px 8px rgba(42, 42, 42, .08);--shadow-lg: 0 4px 16px rgba(42, 42, 42, .12)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-sans);background:var(--tnc-cream);color:var(--tnc-dark);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem 1.25rem;font-size:.9rem;font-weight:600;font-family:var(--font-sans);border:2px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease;text-decoration:none;width:100%}.btn-primary{background:var(--tnc-green);color:var(--tnc-white)}.btn-primary:hover{background:var(--tnc-green-dark);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--tnc-white);color:var(--tnc-dark);border-color:var(--tnc-gray-300)}.btn-secondary:hover{border-color:var(--tnc-dark)}.btn-danger{background:var(--tnc-coral);color:var(--tnc-white)}.btn-danger:hover{background:#b04e30}.btn-sm{padding:.4rem .9rem;font-size:.8rem}.btn-lg{padding:.75rem 1.75rem;font-size:1rem}.btn:disabled{opacity:.45;cursor:not-allowed}.badge{display:inline-flex;align-items:center;padding:.2rem .65rem;font-size:.7rem;font-weight:700;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.04em}.badge-green{background:var(--tnc-green-light);color:var(--tnc-green-dark)}.badge-yellow{background:var(--tnc-yellow-light);color:#9a7e10}.badge-coral{background:var(--tnc-coral-light);color:var(--tnc-coral)}.badge-sky{background:var(--tnc-sky-light);color:#2e7fa3}.alert{padding:.85rem 1rem;border-radius:var(--radius-md);font-size:.85rem;display:flex;align-items:flex-start;gap:.5rem;margin-bottom:.75rem}.alert-icon{font-size:1.1rem;line-height:1;flex-shrink:0}.alert-success{background:var(--tnc-green-light);color:var(--tnc-green-dark)}.alert-warning{background:var(--tnc-yellow-light);color:#9a7e10}.alert-error{background:var(--tnc-coral-light);color:var(--tnc-coral)}.alert-info{background:var(--tnc-sky-light);color:#2e7fa3}.form-group{display:flex;flex-direction:column;gap:.35rem}.form-label{font-size:.8rem;font-weight:600;color:var(--tnc-gray-700)}.form-input{padding:.6rem .85rem;font-size:.9rem;font-family:var(--font-sans);border:1.5px solid var(--tnc-gray-300);border-radius:var(--radius-md);background:var(--tnc-white);color:var(--tnc-dark);transition:border-color .15s,box-shadow .15s;outline:none;width:100%}.form-input:focus{border-color:var(--tnc-green);box-shadow:0 0 0 3px #7ac14326}.form-input::placeholder{color:var(--tnc-gray-300)}.form-hint{font-size:.75rem;color:var(--tnc-gray-500)}.stamp-card{background:var(--tnc-white);border-radius:var(--radius-xl);padding:1.25rem;box-shadow:var(--shadow-md)}.stamp-card-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.stamp-card-logo{width:40px;height:40px;flex-shrink:0}.stamp-card-biz{font-family:var(--font-display);font-weight:700;font-size:1rem}.stamp-card-sub{font-size:.8rem;color:var(--tnc-gray-500)}.stamp-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.4rem;margin-bottom:.75rem}.stamp-slot{aspect-ratio:1;border-radius:var(--radius-full);border:2px dashed var(--tnc-gray-300);overflow:hidden;position:relative}.stamp-slot .stamp-icon{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-full);opacity:.18;filter:grayscale(1);display:block}.stamp-slot.filled{border:2px solid var(--tnc-green);background:transparent}.stamp-slot.filled .stamp-icon{opacity:1;filter:none}.stamp-slot.filled:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius-full);background:var(--tnc-green);mix-blend-mode:lighten;pointer-events:none}.stamp-slot.reward{border:2px dashed var(--tnc-yellow)}.stamp-slot.reward.earned{border:2px solid var(--tnc-yellow)}.stamp-slot.reward.earned .stamp-icon{opacity:1;filter:none}.stamp-card-progress{font-size:.85rem;color:var(--tnc-gray-500);text-align:center}.stamp-card-progress strong{color:var(--tnc-green-dark)}.logo-green-mask-wrap{position:relative;display:inline-block;border-radius:var(--radius-full);overflow:hidden}.logo-green-mask-wrap img{display:block;border-radius:var(--radius-full)}.logo-green-mask-wrap:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius-full);background:var(--tnc-green);mix-blend-mode:lighten}
