*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,SF Pro Text,Roboto,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f7fa;color:#111827;min-height:100vh;min-height:100dvh}html{height:100%;min-height:100%;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}#root{min-height:100vh;min-height:100dvh}.app{max-width:480px;margin:0 auto;min-height:100vh;min-height:100dvh;padding-top:env(safe-area-inset-top);background:#fff;position:relative}a{color:inherit;text-decoration:none}button,input,select{font-family:inherit}.lh-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;padding:12px 24px;border:none;border-radius:9999px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit}.lh-btn:active{transform:scale(.98)}.lh-btn:disabled{opacity:.5;cursor:not-allowed}.lh-btn--primary{background:#10b981;color:#fff}.lh-btn--primary:hover:not(:disabled){background:#059669}.lh-btn--secondary{background:#fff;color:#10b981;border:2px solid #10B981}.lh-btn--secondary:hover:not(:disabled){background:#f0fdf4}.lh-btn--ghost{background:transparent;color:#6b7280}.lh-btn--ghost:hover:not(:disabled){background:#f3f4f6}.lh-btn--sm{min-height:36px;padding:8px 16px;font-size:12px}.lh-btn--lg{min-height:48px;padding:14px 28px;font-size:16px}.lh-btn--full{width:100%}.lh-btn__icon{display:flex;align-items:center}.onboarding{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;padding:24px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.onboarding__content{flex:1;display:flex;flex-direction:column;justify-content:center;gap:48px}.onboarding__header{text-align:center}.onboarding__logo{font-size:32px;font-weight:700;margin:0}.onboarding__slide{text-align:center;padding:0 16px}.onboarding__title{font-size:24px;font-weight:700;margin:0 0 16px;line-height:1.3}.onboarding__description{font-size:16px;opacity:.9;line-height:1.5;margin:0}.onboarding__dots{display:flex;justify-content:center;gap:8px}.onboarding__dot{width:8px;height:8px;border-radius:50%;background:#ffffff4d;transition:all .3s ease}.onboarding__dot--active{width:24px;border-radius:4px;background:#fff}.onboarding__footer{display:flex;flex-direction:column;gap:12px}.otp{min-height:100vh;padding:48px 16px 24px;background:#f5f7fa}.otp__header{margin-bottom:32px}.otp__title{font-size:24px;font-weight:700;color:#111827;margin:0 0 8px}.otp__subtitle{font-size:14px;color:#6b7280;margin:0}.otp__form{display:flex;flex-direction:column;gap:20px;align-items:center}.otp__inputs{display:flex;gap:12px;justify-content:center}.otp__input{width:56px;height:56px;text-align:center;font-size:24px;font-weight:600;border:2px solid #E5E7EB;border-radius:12px;transition:border-color .2s ease}.otp__input:focus{outline:none;border-color:#10b981}.otp__error{color:#ef4444;font-size:12px;margin:0}.otp__resend{background:none;border:none;color:#6b7280;font-size:12px;cursor:pointer;text-decoration:underline}.otp__helper{font-size:12px;color:#9ca3af;margin:0}.lh-card{background:#fff;border-radius:16px;padding:16px}.lh-card--default{box-shadow:0 8px 16px #0f172a0f}.lh-card--outlined{border:1px solid #E5E7EB;box-shadow:none}.wallet{min-height:100vh;padding:16px 16px 72px;background:#f5f7fa}.wallet__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.wallet__greeting{font-size:20px;font-weight:600;color:#111827;margin:0 0 4px}.wallet__subtitle{font-size:12px;color:#6b7280;margin:0}.wallet__avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600}.wallet__summary{margin-bottom:24px}.wallet__summary-content{display:flex;justify-content:space-between;align-items:center}.wallet__summary-label{font-size:12px;color:#6b7280;margin:0 0 4px}.wallet__summary-value{font-size:28px;font-weight:700;color:#10b981;margin:0 0 4px}.wallet__summary-hint{font-size:12px;color:#6b7280;margin:0}.wallet__programs-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.wallet__programs-header h2{font-size:18px;font-weight:600;color:#111827;margin:0}.wallet__sort{padding:6px 12px;border:1px solid #E5E7EB;border-radius:8px;font-size:12px;background:#fff}.wallet__programs-list{display:flex;flex-direction:column;gap:12px}.wallet__program-card{display:flex;gap:12px;padding:16px;background:#fff;border-radius:16px;box-shadow:0 4px 8px #0f172a0a;text-decoration:none;color:inherit;transition:transform .2s ease}.wallet__program-card:active{transform:scale(.98)}.wallet__program-logo{width:48px;height:48px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.wallet__program-logo img{width:100%;height:100%;object-fit:contain;display:block}.wallet__program-info{flex:1}.wallet__program-name{font-size:16px;font-weight:600;color:#111827;margin:0 0 4px}.wallet__program-balance{font-size:14px;font-weight:600;color:#10b981;margin:0 0 2px}.wallet__program-benefit{font-size:12px;color:#6b7280;margin:0 0 4px}.wallet__program-status{display:inline-block;font-size:10px;padding:2px 8px;background:#f3f4f6;color:#6b7280;border-radius:4px}.wallet__fab{position:fixed;right:16px;bottom:72px;width:56px;height:56px;border-radius:50%;background:#10b981;color:#fff;display:flex;align-items:center;justify-content:center;font-size:32px;text-decoration:none;box-shadow:0 4px 12px #10b98166;transition:transform .2s ease}.wallet__fab:active{transform:scale(.95)}.program{min-height:100vh;padding:16px 16px 72px;background:#f5f7fa}.program__back{display:inline-block;margin-bottom:16px;color:#10b981;text-decoration:none;font-size:14px}.program__brand{display:flex;gap:12px;align-items:center;margin-bottom:20px}.program__logo{font-size:48px}.program__name{font-size:20px;font-weight:600;margin:0 0 4px}.program__status{font-size:12px;padding:2px 8px;background:#f3f4f6;color:#6b7280;border-radius:4px}.program__balance{margin-bottom:20px}.program__balance-label{font-size:12px;color:#6b7280;margin:0 0 4px}.program__balance-value{font-size:28px;font-weight:700;color:#10b981;margin:0 0 4px}.program__balance-hint,.program__cashback{font-size:12px;color:#6b7280;margin:0}.program__actions{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.program__operations h2{font-size:18px;font-weight:600;margin:0 0 12px}.program__empty{font-size:14px;color:#6b7280;text-align:center;padding:32px 16px}.add-program{min-height:100vh;padding:16px;background:#f5f7fa}.add-program__back{display:inline-block;margin-bottom:16px;color:#10b981;text-decoration:none;font-size:14px}.add-program__title{font-size:24px;font-weight:700;margin:0 0 24px}.add-program__tabs{display:flex;gap:8px;margin-bottom:24px}.add-program__tab{flex:1;padding:12px;background:#fff;border:1px solid #E5E7EB;border-radius:12px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.add-program__tab--active{background:#10b981;color:#fff;border-color:#10b981}.add-program__qr-section{text-align:center;padding:48px 16px}.add-program__icon{font-size:64px;margin-bottom:16px}.add-program__text{font-size:14px;color:#6b7280;margin:0 0 24px;line-height:1.5}.history{min-height:100vh;padding:16px 16px 72px;background:#f5f7fa}.history__header{margin-bottom:20px}.history__title{font-size:24px;font-weight:700;color:#111827;margin:0}.history__filters{display:flex;gap:8px;margin-bottom:20px}.history__filter{flex:1;padding:10px 12px;border:1px solid #E5E7EB;border-radius:8px;font-size:12px;background:#fff}.history__content{text-align:center;padding:64px 16px}.history__empty{font-size:16px;font-weight:600;color:#111827;margin:0 0 8px}.history__empty-hint{font-size:14px;color:#6b7280;margin:0;line-height:1.5}.lh-textfield{display:flex;flex-direction:column;gap:6px;width:100%}.lh-textfield__label{font-size:12px;font-weight:600;color:#111827}.lh-textfield__input{min-height:44px;padding:12px 16px;border:2px solid #E5E7EB;border-radius:12px;font-size:14px;font-family:inherit;transition:border-color .2s ease}.lh-textfield__input:focus{outline:none;border-color:#10b981}.lh-textfield__input::placeholder{color:#9ca3af}.lh-textfield--error .lh-textfield__input{border-color:#ef4444}.lh-textfield__error{font-size:12px;color:#ef4444}.lh-textfield__helper{font-size:12px;color:#6b7280}.settings{min-height:100vh;padding:16px 16px 72px;background:#f5f7fa}.settings__header{margin-bottom:20px}.settings__title{font-size:24px;font-weight:700;color:#111827;margin:0}.settings__section{margin-bottom:16px}.settings__section-title{font-size:16px;font-weight:600;color:#111827;margin:0 0 16px}.settings__fields{display:flex;flex-direction:column;gap:16px}.settings__toggle{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #F3F4F6;font-size:14px;color:#111827;cursor:pointer}.settings__toggle:last-child{border-bottom:none}.settings__toggle input{width:44px;height:24px;cursor:pointer}.login{min-height:100vh;padding:48px 16px 24px;background:#f5f7fa}.login__header{margin-bottom:32px}.login__title{font-size:24px;font-weight:700;color:#111827;margin:0 0 8px}.login__subtitle{font-size:14px;color:#6b7280;margin:0;line-height:1.5}.login__form{display:flex;flex-direction:column;gap:20px}.login__checkbox{display:flex;align-items:center;gap:8px;font-size:12px;color:#6b7280;cursor:pointer}.login__checkbox input{width:18px;height:18px;cursor:pointer}.login__checkbox a{color:#10b981;text-decoration:none}
