:root{--font-heading: "DM Serif Display", Georgia, serif;--font-body: "DM Sans", system-ui, sans-serif;--color-primary: #2C2C35;--color-primary-hover: #1a1a22;--color-primary-subtle: #f0f0f2;--color-primary-fg: #ffffff;--color-accent: #C9A96E;--color-accent-hover: #b8925a;--color-accent-subtle: #fdf7ee;--color-accent-fg: #2C2C35;--color-success: #3D9970;--color-success-subtle: #edf7f2;--color-warning: #E6A817;--color-warning-subtle: #fef9ec;--color-danger: #E05252;--color-danger-subtle: #fdf0f0;--color-info: #4A90D9;--color-info-subtle: #eef5fd;--color-neutral-100: #f4f4f5;--color-neutral-200: #e4e4e7;--color-neutral-300: #d4d4d8;--color-neutral-700: #3f3f47;--color-background: #f7f7f8;--color-surface: #ffffff;--color-surface-overlay: rgba(44, 44, 53, .6);--color-text-primary: #2C2C35;--color-text-secondary: #52525c;--color-border: #e4e4e7;--radius-sm: .375rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-xl: 1.5rem;--radius-2xl: 2rem;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(44,44,53,.08), 0 1px 2px rgba(44,44,53,.05);--shadow-md: 0 4px 12px rgba(44,44,53,.1), 0 2px 4px rgba(44,44,53,.06);--shadow-lg: 0 8px 24px rgba(44,44,53,.12), 0 4px 8px rgba(44,44,53,.08);--shadow-xl: 0 16px 48px rgba(44,44,53,.16), 0 8px 16px rgba(44,44,53,.1);--shadow-focus: 0 0 0 3px rgba(201,169,110,.35);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-spring: .4s cubic-bezier(.34, 1.56, .64, 1);--z-toast: 500;--z-modal: 300}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);background:var(--color-background);color:var(--color-text-primary);min-height:100dvh;overflow-x:hidden}.app-shell{max-width:480px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column}.app-header{padding:1.25rem 1.25rem 0;display:flex;align-items:center;justify-content:space-between;gap:1rem}.app-header__title{font-family:var(--font-heading);font-size:1.75rem;color:var(--color-primary);line-height:1.1}.app-header__subtitle{font-size:.8rem;color:var(--color-text-secondary);margin-top:.1rem}.app-content{flex:1;padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.mh-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border:2px solid transparent;border-radius:var(--radius-full);font-family:var(--font-body);font-weight:600;line-height:1;letter-spacing:.01em;cursor:pointer;transition:background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-spring);white-space:nowrap;-webkit-user-select:none;user-select:none;transform:translateY(-2px);box-shadow:0 2px #00000040,0 4px 8px #00000026;text-decoration:none}.mh-btn:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 3px #00000040,0 6px 12px #0000002e}.mh-btn:focus-visible{outline:none;box-shadow:0 2px #00000040,var(--shadow-focus)}.mh-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 0 #00000040,0 1px 3px #0000001f}.mh-btn:disabled{box-shadow:none;transform:none;opacity:.45;cursor:not-allowed}.mh-btn--sm{font-size:.875rem;padding:.5rem 1rem;min-height:36px}.mh-btn--md{font-size:1rem;padding:.75rem 1.5rem;min-height:48px}.mh-btn--lg{font-size:1.125rem;padding:1rem 2rem;min-height:56px}.mh-btn--full{width:100%}.mh-btn--primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.mh-btn--primary:hover:not(:disabled){background:var(--color-primary-hover)}.mh-btn--accent{background:var(--color-accent);color:var(--color-accent-fg);border-color:var(--color-accent)}.mh-btn--accent:hover:not(:disabled){background:var(--color-accent-hover)}.mh-btn--secondary{background:transparent;color:var(--color-primary);border-color:var(--color-primary)}.mh-btn--secondary:hover:not(:disabled){background:var(--color-primary-subtle)}.mh-btn--ghost{background:transparent;color:var(--color-text-secondary);border-color:transparent;box-shadow:none;transform:none}.mh-btn--ghost:hover:not(:disabled){background:var(--color-neutral-100);color:var(--color-text-primary);box-shadow:none;transform:none}.mh-btn--ghost:active:not(:disabled){box-shadow:none;transform:none}.mh-btn--success{background:var(--color-success);color:#fff;border-color:var(--color-success)}.mh-btn--danger{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.mh-badge{display:inline-flex;align-items:center;gap:.25rem;font-family:var(--font-body);font-weight:600;letter-spacing:.03em;text-transform:uppercase;white-space:nowrap;box-shadow:inset 0 1px #ffffff73,inset 0 -1px #00000014,0 1px 2px #00000014}.mh-badge--pill{border-radius:var(--radius-full)}.mh-badge--sm{font-size:.65rem;padding:.2rem .6rem}.mh-badge--md{font-size:.75rem;padding:.25rem .75rem}.mh-badge--default{background:var(--color-neutral-100);color:var(--color-neutral-700)}.mh-badge--primary{background:var(--color-primary-subtle);color:var(--color-primary)}.mh-badge--accent{background:var(--color-accent-subtle);color:var(--color-accent-hover)}.mh-badge--success{background:var(--color-success-subtle);color:var(--color-success)}.mh-badge--warning{background:var(--color-warning-subtle);color:var(--color-warning)}.mh-badge--danger{background:var(--color-danger-subtle);color:var(--color-danger)}.mh-badge--dot{gap:.375rem}.mh-badge__dot{width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}.mh-card{border-radius:var(--radius-xl);background:var(--color-surface);overflow:hidden;transition:box-shadow var(--transition-base),transform var(--transition-spring)}.mh-card--default{box-shadow:var(--shadow-sm);border:1px solid var(--color-border)}.mh-card--elevated{box-shadow:var(--shadow-lg)}.mh-card--outlined{border:2px solid var(--color-border)}.mh-card--pad-sm{padding:1rem}.mh-card--pad-md{padding:1.5rem}.mh-card--clickable{cursor:pointer}.mh-card--clickable:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.mh-card__header{padding-bottom:1rem;border-bottom:1px solid var(--color-border);margin-bottom:1rem;display:flex;align-items:center;justify-content:space-between;gap:.75rem}.mh-card__title{font-family:var(--font-heading);font-size:1.25rem;line-height:1.2}.mh-progress{display:flex;align-items:center;gap:.75rem;width:100%}.mh-progress__track{flex:1;background:var(--color-neutral-200);border-radius:var(--radius-full);overflow:hidden}.mh-progress--sm .mh-progress__track{height:6px}.mh-progress--md .mh-progress__track{height:10px}.mh-progress--lg .mh-progress__track{height:16px}.mh-progress__fill{height:100%;border-radius:var(--radius-full);transition:width .6s cubic-bezier(.34,1.56,.64,1);position:relative;overflow:hidden}.mh-progress--accent .mh-progress__fill{background:var(--color-accent)}.mh-progress--success .mh-progress__fill{background:var(--color-success)}.mh-progress--primary .mh-progress__fill{background:var(--color-primary)}.mh-progress__label{font-size:.875rem;font-weight:600;color:var(--color-text-secondary);min-width:3ch;text-align:right}.mh-progress--animated .mh-progress__fill:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.35) 50%,transparent 100%);animation:mh-shimmer 1.5s infinite}@keyframes mh-shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.stamp-grid{display:grid;gap:.5rem}.stamp-grid--5{grid-template-columns:repeat(5,1fr)}.stamp-grid--4{grid-template-columns:repeat(4,1fr)}.stamp-grid--3{grid-template-columns:repeat(3,1fr)}.stamp-cell{aspect-ratio:1;border-radius:var(--radius-md);border:2px dashed var(--color-neutral-300);display:flex;align-items:center;justify-content:center;font-size:1.25rem;transition:all var(--transition-base);background:var(--color-neutral-100)}.stamp-cell--filled{border-color:var(--color-accent);background:var(--color-accent-subtle);border-style:solid}.stamp-cell--filled svg{color:var(--color-accent)}.bonus-card{background:linear-gradient(135deg,var(--color-primary) 0%,#3d3d4a 100%);border-radius:var(--radius-2xl);padding:1.75rem;color:#fff;position:relative;overflow:hidden;box-shadow:var(--shadow-xl)}.bonus-card:before{content:"";position:absolute;top:-40px;right:-40px;width:180px;height:180px;border-radius:50%;background:#c9a96e26;pointer-events:none}.bonus-card:after{content:"";position:absolute;bottom:-60px;left:-20px;width:220px;height:220px;border-radius:50%;background:#c9a96e14;pointer-events:none}.bonus-card__org{font-size:.72rem;opacity:.6;letter-spacing:.1em;text-transform:uppercase;margin-bottom:.35rem}.bonus-card__name{font-family:var(--font-heading);font-size:1.4rem;margin-bottom:1.25rem}.bonus-card__points-label{font-size:.72rem;opacity:.6;letter-spacing:.08em;text-transform:uppercase}.bonus-card__points{font-family:var(--font-heading);font-size:2.75rem;line-height:1;color:var(--color-accent)}.bonus-card__points span{font-size:1rem;opacity:.7;font-family:var(--font-body)}.bonus-card__progress-section{margin-top:1.25rem}.bonus-card__progress-label{display:flex;justify-content:space-between;font-size:.78rem;opacity:.7;margin-bottom:.5rem}.bonus-card__track{height:8px;background:#fff3;border-radius:99px;overflow:hidden}.bonus-card__fill{height:100%;background:var(--color-accent);border-radius:99px;transition:width .8s cubic-bezier(.34,1.56,.64,1)}.bonus-card--full .bonus-card__fill{background:var(--color-success)}.bonus-card--full{background:linear-gradient(135deg,#1e4d3a,#2a6b50)}.mh-toast{position:fixed;top:0;left:50%;transform:translate(-50%) translateY(-120%);z-index:var(--z-toast);background:var(--color-success);color:#fff;padding:1rem 1.75rem;border-radius:0 0 var(--radius-xl) var(--radius-xl);box-shadow:var(--shadow-xl);display:flex;align-items:center;gap:.75rem;font-weight:600;font-size:1.05rem;min-width:280px;max-width:440px;width:max-content;transition:transform .4s cubic-bezier(.34,1.56,.64,1);text-align:center}.mh-toast--visible{transform:translate(-50%) translateY(0)}.mh-toast--error{background:var(--color-danger)}.mh-toast__icon{font-size:1.5rem;flex-shrink:0}.mh-toast__title{font-size:1rem;font-weight:700}.mh-toast__sub{font-size:.85rem;opacity:.85;margin-top:.1rem}.mh-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-surface-overlay);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;z-index:var(--z-modal);animation:mh-overlay-in .2s ease;padding:0}.mh-modal{background:var(--color-surface);border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;width:100%;max-width:480px;max-height:90dvh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:mh-modal-in .35s cubic-bezier(.34,1.56,.64,1)}.mh-modal__handle{width:40px;height:4px;background:var(--color-neutral-300);border-radius:var(--radius-full);margin:.75rem auto 0}.mh-modal__header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.25rem 1.5rem 0}.mh-modal__title{font-family:var(--font-heading);font-size:1.4rem}.mh-modal__close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:50%;background:var(--color-neutral-100);color:var(--color-text-secondary);cursor:pointer;transition:background var(--transition-fast);flex-shrink:0}.mh-modal__close:hover{background:var(--color-neutral-200)}.mh-modal__body{padding:1.25rem 1.5rem 2rem}@keyframes mh-overlay-in{0%{opacity:0}to{opacity:1}}@keyframes mh-modal-in{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:none}}.mh-divider{height:1px;background:var(--color-border);margin:1rem 0}.mh-section-label{font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-secondary);margin-bottom:.75rem}.mh-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1.5rem;text-align:center;color:var(--color-text-secondary);gap:.75rem}.mh-empty__icon{font-size:3rem;opacity:.4}.mh-empty__title{font-family:var(--font-heading);font-size:1.2rem;color:var(--color-text-primary)}.mh-empty__text{font-size:.9rem;line-height:1.6;max-width:280px}.mh-loading{display:flex;align-items:center;justify-content:center;padding:3rem;flex-direction:column;gap:1rem;color:var(--color-text-secondary)}.mh-spinner{width:32px;height:32px;border:3px solid var(--color-neutral-200);border-top-color:var(--color-accent);border-radius:50%;animation:mh-spin .8s linear infinite}@keyframes mh-spin{to{transform:rotate(360deg)}}.mh-error-card{background:var(--color-danger-subtle);border:1px solid rgba(224,82,82,.25);border-radius:var(--radius-xl);padding:1.5rem;text-align:center;color:var(--color-danger)}.mh-input-group{display:flex;flex-direction:column;gap:.4rem}.mh-label{font-size:.8rem;font-weight:600;color:var(--color-text-secondary);letter-spacing:.02em}.mh-input{width:100%;padding:.75rem 1rem;border:2px solid var(--color-border);border-radius:var(--radius-md);font-family:var(--font-body);font-size:1rem;color:var(--color-text-primary);background:var(--color-surface);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);-webkit-appearance:none}.mh-input:focus{outline:none;border-color:var(--color-accent);box-shadow:var(--shadow-focus)}.mh-input::placeholder{color:var(--color-neutral-300)}.mh-select{width:100%;padding:.75rem 2.5rem .75rem 1rem;border:2px solid var(--color-border);border-radius:var(--radius-md);font-family:var(--font-body);font-size:1rem;color:var(--color-text-primary);background:var(--color-surface);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2352525c' stroke-width='2.5' stroke-linecap='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.mh-select:focus{outline:none;border-color:var(--color-accent);box-shadow:var(--shadow-focus)}.qr-scanner-wrap{width:100%;border-radius:var(--radius-xl);overflow:hidden;background:#000;position:relative}#qr-reader{width:100%!important;border:none!important;border-radius:var(--radius-xl)!important}#qr-reader video{border-radius:var(--radius-xl)}#qr-reader__scan_region{border-radius:var(--radius-xl)}#qr-reader__dashboard{display:none!important}.qr-overlay-label{position:absolute;bottom:.75rem;left:50%;transform:translate(-50%);background:#0009;color:#ffffffe6;font-size:.78rem;font-weight:500;padding:.35rem .85rem;border-radius:var(--radius-full);white-space:nowrap;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1rem;display:flex;flex-direction:column;gap:.25rem}.stat-card__label{font-size:.72rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.06em}.stat-card__value{font-family:var(--font-heading);font-size:1.75rem;color:var(--color-primary);line-height:1}.stat-card__sub{font-size:.78rem;color:var(--color-text-secondary)}.mh-list-item{display:flex;align-items:center;gap:.75rem;padding:.875rem 0;border-bottom:1px solid var(--color-border)}.mh-list-item:last-child{border-bottom:none}.mh-list-item__avatar{width:40px;height:40px;border-radius:var(--radius-md);background:var(--color-neutral-100);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;overflow:hidden}.mh-list-item__avatar img{width:100%;height:100%;object-fit:cover}.mh-list-item__body{flex:1;min-width:0}.mh-list-item__title{font-weight:600;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mh-list-item__sub{font-size:.78rem;color:var(--color-text-secondary);margin-top:.1rem}.mh-list-item__end{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem;flex-shrink:0}.archive-toggle{display:flex;align-items:center;gap:.5rem;font-size:.82rem;font-weight:600;color:var(--color-text-secondary);cursor:pointer;background:none;border:none;padding:.5rem;border-radius:var(--radius-md);transition:color var(--transition-fast),background var(--transition-fast)}.archive-toggle:hover{color:var(--color-text-primary);background:var(--color-neutral-100)}.issuer-group{display:flex;flex-direction:column;gap:.75rem}.issuer-group__header{display:flex;align-items:center;gap:.625rem;margin-bottom:.25rem}.issuer-group__logo{width:28px;height:28px;border-radius:var(--radius-sm);background:var(--color-neutral-100);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.issuer-group__logo img{width:100%;height:100%;object-fit:cover}.issuer-group__name{font-family:var(--font-heading);font-size:1.1rem;color:var(--color-primary)}.merchant-header{background:var(--color-primary);border-radius:var(--radius-xl);padding:1.25rem 1.5rem;color:#fff;display:flex;flex-direction:column;gap:.25rem}.merchant-header__label{font-size:.72rem;opacity:.6;text-transform:uppercase;letter-spacing:.1em}.merchant-header__name{font-family:var(--font-heading);font-size:1.35rem}.merchant-header__pos{font-size:.82rem;opacity:.7}@keyframes fade-in-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}.animate-in{animation:fade-in-up .35s ease both}.animate-in--1{animation-delay:.05s}.animate-in--2{animation-delay:.1s}.animate-in--3{animation-delay:.15s}.animate-in--4{animation-delay:.2s}.animate-in--5{animation-delay:.25s}.text-secondary{color:var(--color-text-secondary)}.text-sm{font-size:.875rem}.text-xs{font-size:.78rem}.font-heading{font-family:var(--font-heading)}.gap-sm{gap:.5rem}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.w-full{width:100%}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}
