*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f5f5f0;color:#2c2c2a;min-height:100vh;-webkit-font-smoothing:antialiased}.app-shell{display:flex;flex-direction:column;min-height:100vh}.app-header{background:#04342c;padding:14px 20px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}.app-header-logo{display:flex;align-items:center;gap:10px}.app-header-logo-text{font-size:18px;font-weight:700;color:#1d9e75;letter-spacing:.5px}.app-header-merchant{font-size:11px;color:#ffffff73;margin-top:1px}.logout-icon{background:none;border:none;cursor:pointer;color:#ffffff80;padding:6px;border-radius:6px;transition:color .15s;display:flex;align-items:center}.logout-icon:hover{color:#ffffffe6}.page-content{flex:1;padding:20px 16px 100px;max-width:600px;margin:0 auto;width:100%}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #E8E6E0;display:flex;z-index:100;padding-bottom:env(safe-area-inset-bottom)}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;padding:10px 4px 8px;cursor:pointer;color:#888780;font-size:10px;font-weight:500;gap:4px;border:none;background:none;transition:color .15s;font-family:inherit}.bottom-nav-item.active{color:#0f6e56}.bottom-nav-item svg{width:22px;height:22px}.card{background:#fff;border:1px solid #E8E6E0;border-radius:12px;padding:18px;margin-bottom:14px}.card-title{font-size:13px;font-weight:600;color:#04342c;margin-bottom:14px}.kpi-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}.kpi{background:#fff;border:1px solid #E8E6E0;border-radius:12px;padding:14px 16px}.kpi-label{font-size:10px;color:#888780;font-weight:600;text-transform:uppercase;letter-spacing:.3px;margin-bottom:6px}.kpi-value{font-size:26px;font-weight:700;color:#2c2c2a;line-height:1}.kpi-delta{font-size:11px;margin-top:4px;font-weight:500}.up{color:#0f6e56}.down{color:#a32d2d}.kpi-good{border-left:3px solid #0F6E56}.kpi-purple{border-left:3px solid #534AB7}.points-hero{background:#04342c;border-radius:14px;padding:24px 20px;margin-bottom:14px;color:#fff;position:relative;overflow:hidden}.points-hero-label{font-size:11px;color:#ffffff80;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.points-hero-value{font-size:48px;font-weight:700;color:#1d9e75;line-height:1;margin-bottom:4px}.points-hero-sub{font-size:12px;color:#ffffff73}.points-hero-row{display:flex;gap:24px;margin-top:18px;padding-top:18px;border-top:1px solid rgba(255,255,255,.1)}.points-hero-stat-label{font-size:10px;color:#ffffff73;margin-bottom:2px}.points-hero-stat-value{font-size:16px;font-weight:600;color:#fff}.greeting{margin-bottom:18px}.greeting-name{font-size:20px;font-weight:700;color:#04342c}.greeting-sub{font-size:13px;color:#888780;margin-top:2px}.section-title{font-size:13px;font-weight:600;color:#04342c;margin-bottom:10px;margin-top:6px}.ledger-item{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid #F1EFE8}.ledger-item:last-child{border-bottom:none}.ledger-desc{font-size:13px;color:#2c2c2a;margin-bottom:2px}.ledger-date{font-size:11px;color:#888780}.ledger-amount-earn{font-size:15px;font-weight:700;color:#0f6e56}.ledger-amount-redeem{font-size:15px;font-weight:700;color:#a32d2d}.badge{font-size:10px;padding:2px 8px;border-radius:10px;font-weight:600}.badge-earn{background:#e1f5ee;color:#0f6e56}.badge-redeem{background:#fce8e8;color:#a32d2d}.badge-promo{background:#eeedfe;color:#534ab7}.campaign-card{background:#fff;border:1px solid #E8E6E0;border-radius:12px;padding:16px;margin-bottom:10px;cursor:pointer;transition:all .15s}.campaign-card:hover{box-shadow:0 4px 16px #00000014}.campaign-discount{display:inline-block;background:#e1f5ee;color:#0f6e56;font-size:12px;font-weight:700;padding:3px 10px;border-radius:10px;margin-bottom:8px}.campaign-name{font-size:14px;font-weight:600;color:#2c2c2a;margin-bottom:4px}.campaign-desc{font-size:12px;color:#5f5e5a}.auth-page{min-height:100vh;background:#f5f5f0;display:flex;align-items:center;justify-content:center;padding:24px 16px}.auth-card{background:#fff;border:1px solid #E8E6E0;border-radius:16px;padding:32px 24px;width:100%;max-width:400px}.auth-logo{text-align:center;margin-bottom:24px}.auth-logo-name{font-size:28px;font-weight:700;color:#04342c;letter-spacing:-.5px}.auth-logo-sub{font-size:12px;color:#888780;margin-top:2px}.auth-title{font-size:16px;font-weight:600;color:#2c2c2a;margin-bottom:20px}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field label{font-size:12px;font-weight:600;color:#33322e}.field input,.field select{padding:10px 12px;border:1px solid #E8E6E0;border-radius:8px;font-size:14px;font-family:inherit;color:#2c2c2a;background:#fff;outline:none;transition:border-color .15s;width:100%;-webkit-appearance:none}.field input:focus,.field select:focus{border-color:#0f6e56}.btn{width:100%;padding:12px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;border:none;font-family:inherit;transition:all .15s;margin-top:4px}.btn-primary{background:#0f6e56;color:#fff}.btn-primary:hover{background:#04342c}.btn-primary:disabled{background:#b6e5d4;cursor:not-allowed}.auth-link{text-align:center;margin-top:16px;font-size:13px;color:#888780}.auth-link a{color:#0f6e56;text-decoration:none;font-weight:500}.error-msg{background:#fce8e8;color:#a32d2d;font-size:12px;padding:10px 12px;border-radius:8px;margin-bottom:14px}.success-msg{background:#e1f5ee;color:#0f6e56;font-size:12px;padding:10px 12px;border-radius:8px;margin-bottom:14px}.profile-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-top:10px}.profile-stat{text-align:center;padding:12px 8px;background:#f5f5f0;border-radius:10px}.profile-stat-value{font-size:20px;font-weight:700;color:#0f6e56}.profile-stat-label{font-size:10px;color:#888780;margin-top:2px}.empty-state{text-align:center;padding:40px 20px;color:#888780}.empty-state-icon{font-size:40px;margin-bottom:8px}.empty-state-title{font-size:14px;font-weight:600;margin-bottom:4px;color:#5f5e5a}.empty-state-sub{font-size:12px}
