*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,system-ui,sans-serif;background:#f5f5f7;color:#1a1a2e;min-height:100vh}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:16px;color:#666}.spinner{width:40px;height:40px;border:3px solid #e0e0e0;border-top-color:#6c63ff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#6c63ff,#3f3d8f);padding:24px 16px}.login-card{background:#fff;border-radius:20px;padding:40px 32px;width:100%;max-width:420px;box-shadow:0 20px 60px #00000026}.login-brand{text-align:center;margin-bottom:32px}.brand-icon{font-size:48px;display:block;margin-bottom:8px}.brand-name{font-size:26px;font-weight:700;color:#6c63ff}.brand-event{font-size:13px;font-weight:700;color:#f59e0b;letter-spacing:.5px;margin-top:2px}.brand-tagline{font-size:13px;color:#888;margin-top:4px}.auth-form,.invoice-form{display:flex;flex-direction:column;gap:20px}.invoice-info-box{background:#eff6ff;border:1px solid #bfdbfe;border-radius:10px;padding:12px 16px;font-size:13.5px;color:#1e40af;line-height:1.6}.invoice-warning-box{background:#fffbeb;border:1px solid #fcd34d;border-radius:10px;padding:12px 16px;font-size:13.5px;color:#92400e;line-height:1.6}.history-admin-note{margin:6px 0 0;font-size:12px;color:#dc2626;background:#fff5f5;border-left:3px solid #dc2626;padding:4px 8px;border-radius:4px;line-height:1.5}.form-title{font-size:22px;font-weight:700;color:#1a1a2e}.form-subtitle{font-size:14px;color:#666;margin-top:-12px;line-height:1.5}.input-group{display:flex;flex-direction:column;gap:6px}.input-label{font-size:13px;font-weight:600;color:#444;text-transform:uppercase;letter-spacing:.5px}.input{width:100%;padding:12px 14px;border:1.5px solid #ddd;border-radius:10px;font-size:15px;font-family:inherit;transition:border-color .2s;background:#fafafa}.input:focus{outline:none;border-color:#6c63ff;background:#fff}.phone-input-wrapper{display:flex;align-items:center;border:1.5px solid #ddd;border-radius:10px;overflow:hidden;background:#fafafa;transition:border-color .2s}.phone-input-wrapper:focus-within{border-color:#6c63ff;background:#fff}.phone-prefix{padding:12px;font-size:15px;font-weight:600;background:#f0f0f0;color:#555;border-right:1.5px solid #ddd;white-space:nowrap}.phone-input{border:none;border-radius:0;background:transparent;flex:1;letter-spacing:1px}.phone-input:focus{outline:none}.otp-input{font-size:24px;letter-spacing:8px;text-align:center}.amount-input-wrapper{display:flex;align-items:center;border:1.5px solid #ddd;border-radius:10px;overflow:hidden;background:#fafafa;transition:border-color .2s}.amount-input-wrapper:focus-within{border-color:#6c63ff;background:#fff}.amount-prefix{padding:12px;font-size:16px;font-weight:700;background:#f0f0f0;color:#555;border-right:1.5px solid #ddd}.amount-input{border:none;border-radius:0;background:transparent;flex:1}.amount-input:focus{outline:none}.file-upload-label{display:block;cursor:pointer}.file-input-hidden{display:none}.file-upload-inner{display:flex;flex-direction:column;align-items:center;gap:6px;padding:20px;border:2px dashed #c8c8ff;border-radius:10px;background:#f8f7ff;transition:background .2s,border-color .2s}.file-upload-label:hover .file-upload-inner{background:#efefff;border-color:#6c63ff}.file-upload-icon{font-size:28px}.file-upload-text{font-size:14px;font-weight:500;color:#444;text-align:center;word-break:break-word}.file-upload-hint{font-size:12px;color:#999}.progress-bar-track{position:relative;height:8px;background:#e0e0e0;border-radius:99px;overflow:hidden}.progress-bar-fill{height:100%;background:#6c63ff;border-radius:99px;transition:width .3s ease}.progress-label{position:absolute;right:0;top:-20px;font-size:12px;color:#6c63ff;font-weight:600}.btn{padding:13px 20px;border:none;border-radius:10px;font-size:15px;font-weight:600;font-family:inherit;cursor:pointer;transition:opacity .2s,transform .1s}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-primary{background:#6c63ff;color:#fff}.btn-primary:hover:not(:disabled){opacity:.9}.btn-ghost{background:transparent;color:#6c63ff;font-size:14px;padding:10px}.btn-ghost:hover{background:#f0efff}.error-msg{color:#d32f2f;font-size:13px;background:#ffebee;border-radius:8px;padding:10px 12px}.success-banner{color:#1b5e20;font-size:14px;background:#e8f5e9;border-radius:8px;padding:12px 14px;font-weight:500}.app-layout{min-height:100vh;display:flex;flex-direction:column}.app-header{background:#fff;border-bottom:1px solid #eee;position:sticky;top:0;z-index:10}.header-inner{max-width:900px;margin:0 auto;padding:0 20px;height:60px;display:flex;align-items:center;gap:16px}.header-logo{display:flex;align-items:center;gap:8px;flex:1}.logo-icon{font-size:22px}.logo-text-wrap{display:flex;flex-direction:column}.logo-text{font-size:15px;font-weight:700;color:#6c63ff;line-height:1.2}.logo-subtext{font-size:11px;font-weight:500;color:#f59e0b;letter-spacing:.3px}.header-nav{display:flex;gap:4px}.nav-btn{padding:7px 16px;border:1.5px solid #ddd;background:transparent;border-radius:8px;font-size:14px;font-weight:500;font-family:inherit;color:#555;cursor:pointer;transition:all .2s}.nav-btn:hover{border-color:#6c63ff;color:#6c63ff}.nav-btn.active{background:#6c63ff;border-color:#6c63ff;color:#fff}.sign-out-btn{padding:7px 14px;background:transparent;border:1.5px solid #ddd;border-radius:8px;font-size:13px;font-family:inherit;color:#888;cursor:pointer;transition:all .2s}.sign-out-btn:hover{border-color:#d32f2f;color:#d32f2f}.app-main{flex:1;max-width:900px;width:100%;margin:0 auto;padding:32px 20px}.dashboard{display:flex;flex-direction:column;gap:24px}.welcome-card{background:linear-gradient(135deg,#6c63ff,#3f3d8f);color:#fff;border-radius:16px;padding:24px 28px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.welcome-greeting{display:flex;align-items:center;gap:14px}.welcome-wave{font-size:32px}.welcome-name{font-size:20px;font-weight:700}.welcome-sub{font-size:13px;opacity:.8;margin-top:2px}.spend-badge{text-align:right}.spend-label{font-size:12px;opacity:.8;text-transform:uppercase;letter-spacing:.5px}.spend-amount{font-size:26px;font-weight:700}.form-card{background:#fff;border-radius:16px;padding:32px;box-shadow:0 2px 12px #0000000f}.leaderboard-page{display:flex;flex-direction:column;gap:20px}.leaderboard-header{text-align:center}.leaderboard-title{font-size:26px;font-weight:700}.leaderboard-subtitle{font-size:13px;color:#888;margin-top:4px}.public-leaderboard-banner{text-align:center;background:#fffbeb;border:1px solid #fcd34d;border-radius:12px;padding:16px 24px;margin-bottom:24px;display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap}.public-leaderboard-banner p{margin:0;font-size:15px;color:#92400e;font-weight:500}.btn-login-cta{background:#f59e0b;color:#fff;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:700;border:none;cursor:pointer;text-decoration:none;transition:opacity .2s;display:inline-block}.btn-login-cta:hover{opacity:.88}.leaderboard-empty{text-align:center;color:#888;padding:60px 20px;background:#fff;border-radius:16px}.leaderboard-table-wrapper{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 12px #0000000f}.leaderboard-table{width:100%;border-collapse:collapse}.leaderboard-table th{background:#f8f7ff;padding:12px 16px;text-align:left;font-size:12px;font-weight:700;color:#888;text-transform:uppercase;letter-spacing:.5px}.leaderboard-table td{padding:14px 16px;font-size:15px;border-top:1px solid #f0f0f0}.leaderboard-table tr.my-row td{background:#f0efff;font-weight:600}.rank-cell{width:64px}.medal{font-size:22px}.rank-num{font-size:15px;font-weight:700;color:#aaa}.you-badge{font-size:12px;color:#6c63ff;font-weight:700}.count-cell{color:#888}.amount-cell{font-weight:700;color:#2e7d32;text-align:right}.my-rank-card{background:#fff;border-radius:12px;padding:20px 24px;border:2px dashed #c8c8ff;text-align:center}.my-rank-label{font-size:12px;font-weight:700;color:#6c63ff;text-transform:uppercase;letter-spacing:.5px}.my-rank-info{font-size:16px;font-weight:600;margin-top:6px}.my-rank-cta{font-size:13px;color:#888;margin-top:4px}.page-center{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:16px}.success-page{display:flex;align-items:center;justify-content:center;min-height:60vh}.success-card{background:#fff;border-radius:20px;padding:48px 40px;text-align:center;max-width:440px;width:100%;box-shadow:0 4px 24px #00000014}.success-icon{font-size:64px;margin-bottom:16px}.success-title{font-size:26px;font-weight:700;color:#1a1a2e;margin-bottom:12px}.success-message{font-size:15px;color:#666;line-height:1.7;margin-bottom:32px}.success-actions{display:flex;flex-direction:column;gap:10px}.profile-page{display:flex;flex-direction:column;gap:24px}.profile-header-card{background:linear-gradient(135deg,#6c63ff,#3f3d8f);color:#fff;border-radius:16px;padding:24px 28px;display:flex;align-items:center;gap:20px;flex-wrap:wrap}.profile-avatar{width:60px;height:60px;border-radius:50%;background:#ffffff40;display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:700;flex-shrink:0}.profile-info{flex:1}.profile-name{font-size:20px;font-weight:700}.profile-phone{font-size:13px;opacity:.75;margin-top:2px}.profile-stats{display:flex;gap:20px}.stat-box{text-align:right}.stat-value{font-size:20px;font-weight:700}.stat-label{font-size:11px;opacity:.75;text-transform:uppercase;letter-spacing:.5px}.invoice-history-card{background:#fff;border-radius:16px;padding:28px;box-shadow:0 2px 12px #0000000f}.history-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}.history-title{font-size:18px;font-weight:700}.btn-submit-new{padding:9px 18px;font-size:14px}.history-empty{text-align:center;color:#888;padding:40px 20px;line-height:2}.history-table-wrapper{overflow-x:auto}.history-table{width:100%;border-collapse:collapse}.history-table th{background:#f8f7ff;padding:10px 14px;text-align:left;font-size:12px;font-weight:700;color:#888;text-transform:uppercase;letter-spacing:.5px}.history-table td{padding:13px 14px;font-size:14px;border-top:1px solid #f0f0f0}.history-num{color:#bbb;font-weight:600}.history-date{color:#666;white-space:nowrap}.history-store{font-weight:500}.history-status{white-space:nowrap}.history-status-badge{display:inline-block;padding:3px 10px;border-radius:99px;font-size:12px;font-weight:600}.history-amount{font-weight:700;color:#2e7d32;white-space:nowrap}.view-link{color:#6c63ff;font-weight:600;text-decoration:none;font-size:13px}.view-link:hover{text-decoration:underline}.nav-btn-admin{border-color:#f59e0b!important;color:#f59e0b!important}.nav-btn-admin.active{background:#f59e0b!important;color:#fff!important}.admin-page{display:flex;flex-direction:column;gap:20px}.admin-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.admin-title{font-size:22px;font-weight:700}.admin-subtitle{font-size:13px;color:#888;margin-top:2px}.btn-csv{background:#1e7e34;color:#fff;padding:10px 18px;border-radius:8px;font-size:14px;font-weight:600;font-family:inherit;border:none;cursor:pointer;transition:opacity .2s}.btn-csv:hover{opacity:.88}.btn-reset{background:#b91c1c;color:#fff;padding:10px 18px;border-radius:8px;font-size:14px;font-weight:600;font-family:inherit;border:none;cursor:pointer;transition:opacity .2s}.btn-reset:hover{opacity:.88}.btn-reset:disabled{opacity:.55;cursor:not-allowed}.btn-seed{background:#0369a1;color:#fff;padding:10px 18px;border-radius:8px;font-size:14px;font-weight:600;font-family:inherit;border:none;cursor:pointer;transition:opacity .2s}.btn-seed:hover{opacity:.88}.btn-seed:disabled{opacity:.55;cursor:not-allowed}.btn-seed-remove{background:#6b7280;color:#fff;padding:10px 18px;border-radius:8px;font-size:14px;font-weight:600;font-family:inherit;border:none;cursor:pointer;transition:opacity .2s}.btn-seed-remove:hover{opacity:.88}.btn-seed-remove:disabled{opacity:.55;cursor:not-allowed}.admin-filter-row{display:flex;gap:8px}.filter-tab{padding:8px 18px;border:1.5px solid #ddd;background:#fff;border-radius:8px;font-size:14px;font-weight:500;font-family:inherit;color:#555;cursor:pointer;transition:all .2s}.filter-tab:hover{border-color:#6c63ff;color:#6c63ff}.filter-tab.active{background:#6c63ff;border-color:#6c63ff;color:#fff}.admin-empty{text-align:center;color:#888;background:#fff;border-radius:14px;padding:60px 20px;font-size:16px}.admin-table-wrapper{background:#fff;border-radius:14px;overflow-x:auto;box-shadow:0 2px 12px #0000000f}.admin-note-cell{min-width:160px;padding:8px!important}.admin-note-input{width:100%;min-width:150px;padding:6px 8px;border:1px solid #e2e8f0;border-radius:6px;font-size:12px;font-family:inherit;color:#374151;resize:vertical;background:#f9fafb;transition:border-color .2s}.admin-note-input:focus{outline:none;border-color:#6366f1;background:#fff}.admin-table{width:100%;border-collapse:collapse;min-width:860px}.admin-table th{background:#f8f7ff;padding:11px 14px;text-align:left;font-size:11px;font-weight:700;color:#888;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.admin-table td{padding:12px 14px;font-size:13px;border-top:1px solid #f0f0f0;vertical-align:middle}.admin-row.status-approved td{background:#f0fdf4}.admin-row.status-rejected td{background:#fff5f5}.admin-date{color:#666;white-space:nowrap;font-size:12px}.admin-name{font-weight:600}.admin-phone{color:#666;white-space:nowrap}.admin-invno{font-family:monospace;color:#444}.admin-store{font-weight:500}.admin-amount{font-weight:700;color:#2e7d32;white-space:nowrap}.status-badge{font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.admin-actions{display:flex;gap:6px;flex-wrap:wrap}.action-btn{padding:5px 10px;border:none;border-radius:6px;font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;white-space:nowrap;transition:opacity .2s}.action-btn:disabled{opacity:.5;cursor:not-allowed}.approve-btn{background:#dcfce7;color:#16a34a}.approve-btn:hover:not(:disabled){background:#bbf7d0}.reject-btn{background:#fee2e2;color:#dc2626}.reject-btn:hover:not(:disabled){background:#fecaca}.undo-btn{background:#f1f5f9;color:#475569}.undo-btn:hover:not(:disabled){background:#e2e8f0}.loyalty-stat-box{border-left:1px solid rgba(255,255,255,.25);padding-left:20px}.loyalty-points-value{color:#fde68a}.btn-redeem-small{margin-top:6px;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.4);border-radius:6px;padding:4px 10px;font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .2s}.btn-redeem-small:hover{background:#ffffff59}.redemption-page{display:flex;flex-direction:column;gap:24px;max-width:860px;margin:0 auto;width:100%}.redemption-header{text-align:center}.redemption-title{font-size:26px;font-weight:700;margin:8px 0 4px}.redemption-subtitle{font-size:15px;color:#555}.offers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px}.offer-card{background:#fff;border-radius:16px;padding:24px 20px;box-shadow:0 2px 12px #00000012;display:flex;flex-direction:column;gap:10px;transition:transform .15s,box-shadow .15s}.offer-card:not(.offer-card-disabled):hover{transform:translateY(-3px);box-shadow:0 6px 20px #6c63ff26}.offer-card-disabled{opacity:.55}.offer-icon{font-size:40px}.offer-title{font-size:17px;font-weight:700}.offer-desc{font-size:13px;color:#666;line-height:1.5;flex:1}.offer-footer{display:flex;align-items:center;justify-content:space-between;margin-top:8px;gap:8px}.offer-cost{font-size:13px;font-weight:700;color:#6c63ff}.offer-btn{padding:8px 16px;font-size:13px}.offer-btn:disabled{background:#e5e7eb;color:#9ca3af;cursor:not-allowed}.points-info-box{background:#f8f7ff;border:1.5px solid #e0dfff;border-radius:12px;padding:20px 24px;font-size:14px;color:#444;line-height:1.8}.points-info-box h4{font-size:15px;font-weight:700;margin-bottom:6px;color:#1a1a2e}.points-info-box ul{padding-left:20px}.redemption-modal-card{background:#fff;border-radius:20px;padding:36px 32px;max-width:480px;margin:0 auto;width:100%;box-shadow:0 4px 24px #00000014;display:flex;flex-direction:column;gap:14px}.modal-back-btn{background:none;border:none;color:#6c63ff;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;padding:0;align-self:flex-start}.modal-offer-icon{font-size:48px}.modal-offer-title{font-size:22px;font-weight:700}.modal-offer-desc{font-size:14px;color:#666;line-height:1.6}.modal-cost-badge{display:inline-flex;background:#f0efff;color:#6c63ff;font-weight:700;padding:6px 14px;border-radius:99px;font-size:14px;align-self:flex-start}.modal-balance{font-size:14px;color:#555}.modal-insufficient{color:#dc2626;font-weight:600}.modal-form{display:flex;flex-direction:column;gap:16px}.redemption-success-card{background:#fff;border-radius:20px;padding:48px 36px;max-width:480px;margin:0 auto;width:100%;text-align:center;box-shadow:0 4px 24px #00000014}.redemption-success-msg{font-size:15px;color:#555;line-height:1.7;margin-bottom:24px}.confirmation-code-box{background:#f8f7ff;border:2px dashed #c8c8ff;border-radius:12px;padding:20px;margin-bottom:16px}.confirmation-label{font-size:12px;font-weight:700;color:#888;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.confirmation-code{font-size:32px;font-weight:700;letter-spacing:6px;color:#6c63ff;font-family:monospace}.confirmation-hint{font-size:12px;color:#888;margin-top:8px}.remaining-points-msg{font-size:14px;color:#555}@media (max-width: 600px){.login-card{padding:28px 20px}.app-main{padding:20px 12px}.form-card{padding:20px}.welcome-card{flex-direction:column;align-items:flex-start}.spend-badge{text-align:left}.header-inner{gap:8px}.logo-text{font-size:12px}.logo-subtext{display:none}.sign-out-btn{padding:7px 10px;font-size:12px}.leaderboard-table th:nth-child(3),.leaderboard-table td:nth-child(3){display:none}.profile-header-card{flex-direction:column;align-items:flex-start}.profile-stats{margin-top:8px}.stat-box{text-align:left}.history-table th:nth-child(1),.history-table td:nth-child(1){display:none}}
