:root{--color-base: #f5f6f8;--color-surface: #ffffff;--color-surface-hover: #fafbfc;--color-border: rgba(0, 0, 0, .06);--color-border-strong: rgba(0, 0, 0, .12);--color-primary: #e05a3a;--color-primary-hover: #cc4f32;--color-primary-dim: rgba(224, 90, 58, .07);--color-primary-text: #ffffff;--color-success: #1a9a6b;--color-success-dim: rgba(26, 154, 107, .07);--color-warning: #b87a14;--color-warning-dim: rgba(184, 122, 20, .06);--color-danger: #d03e35;--color-danger-dim: rgba(208, 62, 53, .06);--text-primary: #18181b;--text-secondary: #6e6e77;--text-tertiary: #84848d;--text-inverse: #ffffff;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "SF Mono", "Consolas", monospace;--text-xs: .75rem;--text-sm: .8125rem;--text-base: .9375rem;--text-lg: 1.125rem;--text-xl: 1.375rem;--text-2xl: 1.75rem;--weight-medium: 500;--weight-semibold: 600;--weight-bold: 700;--weight-extrabold: 800;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-12: 48px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-pill: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .05), 0 1px 2px rgba(0, 0, 0, .03);--shadow-md: 0 4px 12px rgba(0, 0, 0, .06), 0 1px 4px rgba(0, 0, 0, .03);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .08), 0 2px 8px rgba(0, 0, 0, .03);--shadow-glow: 0 4px 16px rgba(224, 90, 58, .18);--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--duration-fast: .15s;--duration-normal: .25s;--duration-slow: .4s;--header-height: 60px;--sticky-top: var(--header-height);--feed-max-width: 480px;--safe-bottom: env(safe-area-inset-bottom, 0px)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-sans);font-size:var(--text-base);color:var(--text-primary);background:var(--color-base);line-height:1.6;overflow-x:hidden;min-height:100dvh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none;color:inherit;-webkit-appearance:none}button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}img{display:block;max-width:100%}a{color:inherit;text-decoration:none}.app-header{position:fixed;top:0;left:0;right:0;height:var(--header-height);z-index:100;background:var(--color-surface);border-bottom:1px solid var(--color-border)}.app-header__inner{max-width:var(--feed-max-width);margin:0 auto;height:100%;display:flex;align-items:center;justify-content:center;padding:0 var(--space-4);position:relative}.app-header__brand{display:flex;align-items:center}.brand-logo-img{height:36px;width:auto}.alert-strip{display:flex;align-items:center;gap:var(--space-4);background:linear-gradient(135deg,#e05a3a0f,#e05a3a1f);border:1px solid rgba(224,90,58,.15);border-radius:var(--radius-lg);padding:var(--space-4);margin-bottom:var(--space-4);transition:box-shadow var(--duration-normal)}.alert-strip:hover{box-shadow:var(--shadow-sm)}.alert-strip__icon{width:40px;height:40px;border-radius:50%;background:var(--color-primary);color:var(--text-inverse);display:flex;align-items:center;justify-content:center;flex-shrink:0}.alert-strip__body{flex:1;min-width:0}.alert-strip__title{font-size:var(--text-sm);font-weight:var(--weight-bold);color:var(--text-primary);line-height:1.3}.alert-strip__text{font-size:var(--text-xs);color:var(--text-secondary);line-height:1.3}.alert-strip__btn{display:flex;align-items:center;gap:var(--space-1);background:var(--color-primary);color:var(--text-inverse);border:none;border-radius:var(--radius-pill);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);font-weight:var(--weight-semibold);cursor:pointer;white-space:nowrap;flex-shrink:0;min-height:44px;transition:background var(--duration-fast),transform var(--duration-fast)}.alert-strip__btn:hover{background:var(--color-primary-hover);transform:translate(2px)}.alert-strip__btn:disabled{background:var(--color-success);cursor:default;transform:none}.alert-strip__btn:disabled .alert-strip__btn-arrow{display:none}.alert-strip__btn-arrow{transition:transform var(--duration-fast)}.alert-strip__btn:hover .alert-strip__btn-arrow{transform:translate(2px)}.stats-bar{padding:var(--space-4) 0 var(--space-5);margin-bottom:var(--space-2)}.stats-bar__heading{text-align:center;font-size:var(--text-xs);font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);margin-bottom:var(--space-2)}.stats-bar__cards{display:flex;align-items:center;justify-content:center;height:100%;gap:0}.stats-bar__divider{width:1px;height:28px;background:var(--color-border-strong);flex-shrink:0}.stat-card{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:2px}.stat-card__value{font-family:var(--font-mono);font-size:var(--text-2xl);font-weight:var(--weight-extrabold);color:var(--text-primary);line-height:1;letter-spacing:-.03em;font-variant-numeric:tabular-nums}.stat-card__label{font-size:.6875rem;font-weight:var(--weight-medium);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;line-height:1}.feed{max-width:var(--feed-max-width);margin:0 auto;padding:calc(var(--sticky-top) + var(--space-5)) var(--space-4) calc(100px + var(--safe-bottom));min-height:100dvh}.feed__list{display:flex;flex-direction:column;gap:var(--space-3)}.feed__empty[hidden]{display:none}.empty-state{text-align:center;padding:var(--space-12) var(--space-4) var(--space-8)}.empty-state__img{width:120px;height:120px;object-fit:contain;margin:0 auto var(--space-5);animation:float 4s ease-in-out infinite;opacity:.85}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.empty-state__title{font-size:var(--text-xl);font-weight:var(--weight-bold);margin-bottom:var(--space-2);color:var(--text-primary);letter-spacing:-.02em}.empty-state__text{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-6);line-height:1.6;max-width:320px;margin-left:auto;margin-right:auto}.voucher-card{position:relative;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);overflow:hidden;transition:box-shadow var(--duration-normal) var(--ease-in-out),border-color var(--duration-normal);animation:card-enter var(--duration-normal) var(--ease-out) both;animation-delay:calc(var(--card-index, 0) * 60ms)}.voucher-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-border-strong)}@keyframes card-enter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.voucher-card--expired{pointer-events:auto;animation:none}.voucher-card--expired .voucher-card__actions{display:none}.voucher-card--claimed{pointer-events:auto;animation:none}.voucher-card--claimed .voucher-card__actions{display:none}.voucher-card__overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:2;pointer-events:none;border-radius:var(--radius-lg)}.voucher-card--expired .voucher-card__overlay,.voucher-card--claimed .voucher-card__overlay{background:#ffffffbf;-webkit-backdrop-filter:blur(1.5px);backdrop-filter:blur(1.5px)}.voucher-card__overlay-ribbon{position:absolute;top:32px;right:-40px;transform:rotate(35deg);padding:10px 96px;font-size:14px;font-weight:800;letter-spacing:2px;text-transform:uppercase;text-align:center;box-shadow:0 2px 8px #0000001f}.voucher-card__overlay-ribbon--expired{background:#6e6e77;color:#fff}.voucher-card__overlay-ribbon--claimed{background:#10b981;color:#fff}.voucher-card--expiring{animation:card-exit .3s var(--ease-in-out) forwards}@keyframes card-exit{to{opacity:0;transform:translateY(-8px)}}.voucher-card__countdown--expired{background:var(--color-border);color:var(--text-secondary)}.voucher-card__countdown--claimed{background:#d1fae5;color:#065f46}.voucher-card__top{display:flex;flex-direction:column;gap:var(--space-4)}.voucher-card__img{aspect-ratio:8 / 5;object-fit:cover;margin:calc(-1 * var(--space-5)) calc(-1 * var(--space-5)) 0;width:calc(100% + 2 * var(--space-5));max-width:none;border-radius:calc(var(--radius-lg) - 1px) calc(var(--radius-lg) - 1px) 0 0;background:var(--color-border);transition:filter var(--duration-slow) var(--ease-out)}.voucher-card__img--loading{filter:blur(16px);animation:img-pulse 1.8s ease-in-out infinite}@keyframes img-pulse{0%,to{opacity:.6}50%{opacity:1}}.voucher-card__emoji{font-size:2rem;line-height:1;align-self:flex-start;width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--color-base);border-radius:14px}.voucher-card__deal{font-size:var(--text-xl);font-weight:var(--weight-extrabold);color:var(--text-primary);line-height:1.25;letter-spacing:-.025em}.voucher-card__countdown{text-align:center;margin-top:var(--space-4);padding:var(--space-5) var(--space-4);border-radius:var(--radius-md);transition:color var(--duration-fast),background var(--duration-fast)}.voucher-card__countdown-time{display:block;font-family:var(--font-mono);font-weight:var(--weight-extrabold);font-size:2.75rem;font-variant-numeric:tabular-nums;letter-spacing:-.03em;line-height:1}.voucher-card__countdown-label{display:block;font-family:var(--font-sans);font-size:var(--text-xs);font-weight:var(--weight-medium);text-transform:uppercase;letter-spacing:.08em;opacity:.6;margin-top:6px}.voucher-card__countdown--ok{color:var(--color-success);background:var(--color-success-dim)}.voucher-card__countdown--long{color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 10%,transparent)}.voucher-card__countdown--warning{color:var(--color-warning);background:var(--color-warning-dim);animation:timer-fade 2.5s ease-in-out infinite}.voucher-card__countdown--critical{color:var(--color-danger);background:var(--color-danger-dim);animation:timer-fade 1.2s ease-in-out infinite}@keyframes timer-fade{0%,to{opacity:1}50%{opacity:.5}}.voucher-card__footer{display:flex;justify-content:space-between;align-items:center;margin-top:var(--space-3);position:relative}.voucher-card__views{display:inline-flex;align-items:center;gap:5px;color:var(--text-tertiary);font-size:var(--text-xs);font-weight:var(--weight-medium)}.voucher-card__views svg{opacity:.4}.voucher-card__ago{font-size:var(--text-xs);color:var(--text-tertiary)}.voucher-card__report{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:var(--space-2);border-radius:var(--radius-sm);opacity:.4;transition:opacity var(--duration-fast),color var(--duration-fast);min-height:44px;min-width:44px;display:flex;align-items:center;justify-content:center}.voucher-card__report:hover{opacity:1;color:var(--color-danger)}.voucher-card__report--confirm{opacity:1;color:var(--color-danger);font-size:var(--text-xs);font-weight:var(--weight-semibold)}.voucher-card__report--done{opacity:.4;pointer-events:none;font-size:var(--text-xs);color:var(--text-tertiary)}.voucher-card__footer-actions{display:flex;align-items:center;gap:var(--space-1)}.voucher-card__edit{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:var(--space-2);border-radius:var(--radius-sm);opacity:.4;transition:opacity var(--duration-fast),color var(--duration-fast);min-height:44px;min-width:44px;display:flex;align-items:center;justify-content:center}.voucher-card__edit:hover,.voucher-card__edit--active{opacity:1;color:var(--color-primary)}.voucher-card__edit-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-4);margin-top:var(--space-3);animation:editSlideIn var(--duration-normal) var(--ease-out)}@keyframes editSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.edit-panel__field{margin-bottom:var(--space-3)}.edit-panel__label{display:block;font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--text-secondary);margin-bottom:var(--space-1)}.edit-panel__input{width:100%}.edit-panel__price-row{display:flex;align-items:center;gap:var(--space-3)}.edit-panel__price-field{display:flex;align-items:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);overflow:hidden;flex:1;max-width:140px}.edit-panel__prefix{padding:0 0 0 var(--space-3);color:var(--text-tertiary);font-weight:var(--weight-medium);font-size:var(--text-sm)}.text-input.edit-panel__input--price{border:none;border-radius:0;padding-left:var(--space-1);min-height:0;background:transparent;box-shadow:none}.text-input.edit-panel__input--price:focus{border:none;box-shadow:none;background:transparent}.edit-panel__price-field:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-dim)}.edit-panel__free-label{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer;white-space:nowrap}.edit-panel__actions{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--color-border)}.edit-panel__spacer{flex:1}.btn--danger-ghost{background:none;border:1px solid var(--color-danger);color:var(--color-danger);transition:background var(--duration-fast),color var(--duration-fast)}.btn--danger-ghost:hover{background:var(--color-danger);color:var(--text-inverse)}.voucher-card__actions{margin-top:var(--space-4)}.voucher-card__barcode{margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--color-border);animation:barcode-reveal var(--duration-normal) var(--ease-out)}.voucher-card__barcode[hidden]{display:none}@keyframes barcode-reveal{0%{opacity:0;max-height:0}to{opacity:1;max-height:400px}}.voucher-card__qr{background:#fff;border-radius:var(--radius-md);border:1px solid var(--color-border);padding:var(--space-5);display:flex;justify-content:center;margin-bottom:var(--space-3)}.voucher-card__qr canvas{max-width:200px;max-height:200px}.voucher-card__qr-error{color:var(--text-tertiary);font-size:var(--text-sm);text-align:center;padding:var(--space-4)}.voucher-card__barcode-num{display:flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%;text-align:center;font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer;padding:var(--space-3) var(--space-4);min-height:44px;border-radius:var(--radius-sm);transition:background var(--duration-fast),color var(--duration-fast);letter-spacing:.04em}.voucher-card__barcode-num:hover{background:var(--color-base);color:var(--text-primary)}.voucher-card__barcode-num--copied{color:var(--color-success)!important;background:var(--color-success-dim)!important}.voucher-card__barcode-digits{font-family:inherit;font-weight:var(--weight-bold)}.voucher-card__copy-icon{flex-shrink:0;opacity:.35;transition:opacity var(--duration-fast)}.voucher-card__barcode-num:hover .voucher-card__copy-icon{opacity:.65}.voucher-card__hint{text-align:center;font-size:var(--text-xs);color:var(--text-tertiary);margin-top:var(--space-1)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);border-radius:10px;font-weight:var(--weight-semibold);font-size:var(--text-sm);transition:background var(--duration-fast) var(--ease-in-out),color var(--duration-fast) var(--ease-in-out),box-shadow var(--duration-fast) var(--ease-in-out),transform var(--duration-fast) var(--ease-in-out),border-color var(--duration-fast) var(--ease-in-out);min-height:44px;letter-spacing:-.005em;cursor:pointer;border:none;background:none;line-height:1}.btn--primary{width:100%;background:var(--color-primary);color:var(--color-primary-text)}.btn--primary:hover{background:var(--color-primary-hover);box-shadow:var(--shadow-glow)}.btn--primary:active{transform:scale(.98)}.btn--primary:disabled{opacity:.6;cursor:not-allowed;box-shadow:none;transform:none}.btn--primary svg{flex-shrink:0;opacity:.85}.btn--secondary{width:100%;background:transparent;color:var(--text-primary);border:1px solid var(--color-border-strong)}.btn--secondary:hover{background:var(--color-base);border-color:#0003}.btn--ghost{width:100%;background:transparent;color:var(--text-secondary)}.btn--ghost:hover{background:var(--color-base);color:var(--text-primary)}.btn--sm{padding:var(--space-3) var(--space-4);font-size:var(--text-xs);min-height:44px;width:auto}.btn--reveal{gap:var(--space-2)}.btn--reveal svg{flex-shrink:0;opacity:.7}.btn--active{background:var(--text-primary);color:var(--text-inverse)}.btn--active:hover{background:#333;box-shadow:none}.btn--danger{background:var(--color-danger);color:#fff}.btn--danger:hover{background:#b83530}.fab{position:fixed;bottom:calc(20px + var(--safe-bottom));right:20px;width:56px;height:56px;border-radius:16px;background:var(--color-primary);color:var(--color-primary-text);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg),var(--shadow-glow);z-index:50;transition:transform var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast)}.fab:hover{transform:scale(1.06);box-shadow:var(--shadow-lg),0 6px 20px #e05a3a4d}.fab:active{transform:scale(.94)}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0003;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);z-index:150;opacity:0;transition:opacity var(--duration-normal)}.sheet-backdrop.visible{opacity:1}.sheet-backdrop[hidden]{display:none}.sheet{position:fixed;bottom:0;left:0;right:0;background:var(--color-surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;z-index:151;max-height:85dvh;overflow-y:auto;padding:var(--space-5) var(--space-5) calc(var(--space-5) + var(--safe-bottom));transform:translateY(100%);transition:transform var(--duration-slow) var(--ease-out);box-shadow:0 -4px 24px #0000000f}.sheet.visible{transform:translateY(0)}.sheet[hidden]{display:none}.sheet__close{position:absolute;top:var(--space-3);right:var(--space-3);width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:none;background:var(--color-base);border-radius:50%;color:var(--text-secondary);cursor:pointer;z-index:1}.sheet__close:hover{background:var(--color-border-strong)}.upload-step{padding-bottom:var(--space-2)}.upload-step--centered{text-align:center;padding:var(--space-6) 0}.upload-step__header{margin-bottom:var(--space-4)}.upload-step__title{font-size:var(--text-xl);font-weight:var(--weight-bold);letter-spacing:-.025em;color:var(--text-primary);margin-bottom:var(--space-1);line-height:1.3}.upload-step__subtitle{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5;margin-bottom:var(--space-4)}.upload-step__status{font-size:var(--text-sm);color:var(--text-secondary);margin-top:var(--space-4)}.upload-step__progress{display:flex;align-items:center;justify-content:center;gap:var(--space-2);margin-bottom:var(--space-5)}.progress-dot{width:8px;height:8px;border-radius:50%;background:var(--color-border-strong);transition:all var(--duration-fast)}.progress-dot--active{background:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-dim)}.progress-dot--done{background:var(--color-success)}.upload-step__barcode-preview{display:flex;align-items:center;justify-content:center;gap:var(--space-3);font-family:var(--font-mono);font-size:var(--text-base);font-weight:var(--weight-medium);color:var(--text-primary);background:var(--color-base);border:1px dashed var(--color-border-strong);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);margin-bottom:var(--space-4);letter-spacing:.08em}.upload-step__barcode-preview svg{color:var(--color-primary);flex-shrink:0}.upload-step__actions{display:flex;gap:var(--space-3);margin-top:var(--space-5)}.upload-step__actions .btn{flex:1}.capture-options{display:flex;flex-direction:column;gap:var(--space-3)}.capture-option{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);background:var(--color-base);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--duration-fast);text-align:left;width:100%;cursor:pointer}.capture-option:hover{background:var(--color-surface-hover);border-color:var(--color-border-strong);box-shadow:var(--shadow-sm)}.capture-option__icon{flex-shrink:0;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--color-primary-dim);border-radius:var(--radius-sm);color:var(--color-primary)}.capture-option__text{display:flex;flex-direction:column}.capture-option__label{font-weight:var(--weight-semibold);font-size:var(--text-base);color:var(--text-primary);line-height:1.3}.capture-option__hint{font-size:var(--text-xs);color:var(--text-tertiary);margin-top:2px}.manual-entry{margin-top:var(--space-5)}.manual-entry__divider{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);color:var(--text-tertiary);font-size:var(--text-xs);font-weight:var(--weight-medium);text-transform:uppercase;letter-spacing:.06em}.manual-entry__divider:before,.manual-entry__divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.manual-entry__field{display:flex;gap:var(--space-2);align-items:stretch}.manual-entry__field .text-input{flex:1}.manual-entry__field .btn{flex-shrink:0;width:auto}.text-input{padding:var(--space-3) var(--space-4);background:var(--color-base);border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-mono);font-size:var(--text-sm);min-height:44px;transition:border-color var(--duration-fast),box-shadow var(--duration-fast);width:100%}.text-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-dim);background:var(--color-surface)}.text-input::placeholder{color:var(--text-tertiary)}.spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto}.spinner--sm{width:16px;height:16px;border-width:2px;display:inline-block;vertical-align:middle;margin:0}@keyframes spin{to{transform:rotate(360deg)}}.crop-container{margin-bottom:var(--space-3)}.crop-container__label{font-size:.8rem;color:var(--color-text-muted);margin-bottom:var(--space-1);text-align:center}.crop-container__area{border-radius:var(--radius-md);overflow-y:auto;overflow-x:hidden;max-height:50vh;background:var(--color-surface-alt);-webkit-overflow-scrolling:touch;scrollbar-width:none}.crop-container__area::-webkit-scrollbar{display:none}.crop-wrapper{position:relative;touch-action:pan-y;user-select:none;-webkit-user-select:none}.crop-image{display:block}.crop-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0000008c;pointer-events:none}.crop-box{position:absolute;border:2px solid #fff;border-radius:4px;box-shadow:0 0 0 1px #0000004d;cursor:move;touch-action:none}.crop-handle{position:absolute;width:28px;height:28px;background:#fff;border-radius:50%;box-shadow:0 1px 4px #0006;transform:translate(-50%,-50%)}.crop-handle:after{content:"";position:absolute;top:50%;left:50%;width:48px;height:48px;transform:translate(-50%,-50%);border-radius:50%}.crop-handle--nw{top:0;left:0;cursor:nw-resize}.crop-handle--ne{top:0;left:100%;cursor:ne-resize}.crop-handle--sw{top:100%;left:0;cursor:sw-resize}.crop-handle--se{top:100%;left:100%;cursor:se-resize}.deal-search{position:relative;margin-bottom:var(--space-2)}.deal-search__icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--color-text-muted);pointer-events:none}.deal-search__input{width:100%;padding:10px 12px 10px 36px;border:2px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);font-size:var(--text-sm);outline:none;transition:border-color .15s;box-sizing:border-box}.deal-search__input:focus{border-color:var(--color-primary)}.deal-search__input::placeholder{color:var(--color-text-muted)}.deal-search__empty{grid-column:1 / -1;text-align:center;color:var(--color-text-muted);font-size:var(--text-sm);padding:var(--space-4) 0}.deal-picker{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-2);max-height:340px;overflow-y:auto;padding-right:var(--space-1)}.deal-picker::-webkit-scrollbar{width:4px}.deal-picker::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:var(--radius-pill)}.deal-tile{position:relative;display:flex;flex-direction:column;align-items:center;padding:0;background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--duration-normal) var(--ease-out);cursor:pointer;overflow:hidden;text-align:center}.deal-tile:hover{border-color:var(--color-border-strong);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.deal-tile:active{transform:scale(.97)}.deal-tile--selected{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary),var(--shadow-glow)}.deal-tile__thumb{width:100%;aspect-ratio:4 / 3;display:flex;align-items:center;justify-content:center;background:var(--color-base);overflow:hidden}.deal-tile__thumb--emoji{font-size:2rem;background:linear-gradient(135deg,var(--color-base),var(--color-surface))}.deal-tile__img{width:100%;height:100%;object-fit:cover;transition:transform var(--duration-normal) var(--ease-out)}.deal-tile:hover .deal-tile__img{transform:scale(1.05)}.deal-tile__body{display:flex;flex-direction:column;gap:2px;padding:var(--space-2) var(--space-2) var(--space-3);width:100%}.deal-tile__cat{font-size:.625rem;font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary)}.deal-tile__name{font-weight:var(--weight-medium);font-size:var(--text-xs);color:var(--text-primary);line-height:1.3}.deal-tile__check{position:absolute;top:var(--space-2);right:var(--space-2);width:24px;height:24px;border-radius:50%;background:var(--color-primary);color:var(--text-inverse);display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.5);transition:all var(--duration-normal) var(--ease-out)}.deal-tile--selected .deal-tile__check{opacity:1;transform:scale(1)}.custom-name-entry,.price-entry{margin-top:var(--space-4)}.price-entry__label{display:block;font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text-secondary);margin-bottom:var(--space-2)}.price-entry__row{display:flex;align-items:center;gap:var(--space-3)}.price-entry__field{display:flex;align-items:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);overflow:hidden;flex:1;max-width:140px}.price-entry__prefix{padding:var(--space-2) 0 var(--space-2) var(--space-3);font-family:var(--font-mono);font-size:var(--text-base);font-weight:var(--weight-semibold);color:var(--text-secondary);-webkit-user-select:none;user-select:none}.text-input--price{border:none;background:transparent;font-family:var(--font-mono);font-size:var(--text-base);letter-spacing:.02em;padding:var(--space-2) var(--space-3) var(--space-2) var(--space-1);width:100%}.text-input--price:disabled{opacity:.4}.price-entry__free{display:flex;align-items:center;gap:var(--space-2);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.price-entry__free input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-primary);cursor:pointer}.price-entry__free-label{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text-primary)}.voucher-type-entry{margin-top:var(--space-4)}.voucher-type__toggle{display:flex;gap:var(--space-2);margin-top:var(--space-2)}.voucher-type__btn{flex:1;padding:var(--space-2) var(--space-3);border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--text-secondary);font-size:var(--text-sm);font-weight:var(--weight-medium);cursor:pointer;transition:all var(--duration-fast) var(--ease-in-out)}.voucher-type__btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.voucher-type__btn--active{border-color:var(--color-primary);background:var(--color-primary);color:#fff}.voucher-type__expiry{margin-top:var(--space-3)}.ep{margin-top:var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;background:var(--color-surface)}.ep__days{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;padding:var(--space-2)}.ep__day{display:flex;flex-direction:column;align-items:center;gap:1px;padding:6px 2px;border:1px solid transparent;border-radius:var(--radius-sm);background:transparent;color:var(--text-primary);cursor:pointer;-webkit-tap-highlight-color:transparent;outline:none;transition:background var(--duration-fast) var(--ease-in-out),border-color var(--duration-fast) var(--ease-in-out)}.ep__day:hover{background:var(--color-primary-dim)}.ep__day.ep__day--sel,.ep__day.ep__day--sel:hover{background:var(--color-primary);border-color:var(--color-primary);box-shadow:var(--shadow-glow);color:#fff}.ep__day--sel .ep__day-label,.ep__day--sel .ep__day-date{color:inherit}.ep__day-label{font-size:.6rem;font-weight:var(--weight-semibold);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.03em;line-height:1.2}.ep__day-date{font-size:.7rem;font-weight:var(--weight-bold);color:var(--text-primary);white-space:nowrap;line-height:1.2}.ep__time{border-top:1px solid var(--color-border);padding:var(--space-3) 0;background:var(--color-base)}.ep__spinner{display:flex;align-items:center;justify-content:center;gap:2px;width:60%;max-width:220px;margin:0 auto}.ep__col{display:flex;flex-direction:column;align-items:center;gap:2px}.ep__arrow{width:36px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;border-radius:var(--radius-sm);color:var(--text-tertiary);cursor:pointer;transition:all var(--duration-fast) var(--ease-in-out)}.ep__arrow:hover{background:var(--color-primary-dim);color:var(--color-primary)}.ep__arrow:active{transform:scale(.9)}.ep__digit{font-family:var(--font-mono);font-size:1.5rem;font-weight:var(--weight-bold);color:var(--text-primary);width:44px;text-align:center;line-height:1;padding:4px 0;border-radius:var(--radius-sm);background:var(--color-surface);border:1px solid var(--color-border)}.ep__colon{font-family:var(--font-mono);font-size:1.5rem;font-weight:var(--weight-bold);color:var(--text-tertiary);line-height:1;padding:0 2px;align-self:center}.ep__ampm{font-size:var(--text-xs);font-weight:var(--weight-bold);color:#fff;background:var(--color-primary);border:none;border-radius:var(--radius-sm);padding:6px 10px;margin-left:6px;cursor:pointer;transition:all var(--duration-fast) var(--ease-in-out);line-height:1;letter-spacing:.03em;align-self:center}.ep__ampm:hover{background:var(--color-primary-hover)}.ep__ampm:active{transform:scale(.93)}.picker-continue{width:100%;margin-top:var(--space-4)}.confirm-card{background:var(--color-base);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-5);text-align:center;margin-bottom:var(--space-2)}.confirm-card__deal{display:flex;align-items:center;justify-content:center;gap:var(--space-3);margin-bottom:var(--space-3)}.confirm-card__img{width:100%;aspect-ratio:400 / 250;object-fit:cover;border-radius:var(--radius-sm);margin-bottom:var(--space-3)}.confirm-card__emoji{font-size:1.75rem}.confirm-card__name{font-size:var(--text-lg);font-weight:var(--weight-bold);color:var(--text-primary);letter-spacing:-.01em}.confirm-card__barcode{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-secondary);letter-spacing:.04em;margin-bottom:var(--space-3)}.confirm-card__timer{display:flex;align-items:center;justify-content:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--text-tertiary);font-weight:var(--weight-medium)}.confirm-card__timer svg{opacity:.5;flex-shrink:0}.confirm-fields{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-3)}.confirm-field__label{display:block;font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:var(--space-1)}.confirm-field__expiry{margin-top:var(--space-2)}.success-mark{width:64px;height:64px;background:var(--color-success-dim);color:var(--color-success);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-5);animation:pop var(--duration-normal) var(--ease-out)}.success-done{margin-top:var(--space-5)}.error-mark{width:64px;height:64px;background:var(--color-danger-dim);color:var(--color-danger);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-5);animation:pop var(--duration-normal) var(--ease-out)}@keyframes pop{0%{transform:scale(0)}70%{transform:scale(1.1)}to{transform:scale(1)}}.toast-container{position:fixed;bottom:calc(var(--space-6) + 72px);left:50%;transform:translate(-50%);z-index:300;width:calc(100% - var(--space-8));max-width:400px;display:flex;flex-direction:column-reverse;gap:var(--space-2);pointer-events:none}.toast{border-radius:100px;padding:var(--space-3) var(--space-5);font-size:var(--text-sm);font-weight:var(--weight-semibold);box-shadow:0 8px 24px #00000026;pointer-events:auto;display:flex;align-items:center;gap:var(--space-3);opacity:0;transform:translateY(12px) scale(.95);transition:opacity var(--duration-normal) var(--ease-out),transform var(--duration-normal) var(--ease-out)}.toast--visible{opacity:1;transform:translateY(0) scale(1)}.toast--exit{animation:toast-out var(--duration-fast) var(--ease-in-out) forwards}.toast--clickable{cursor:pointer}.toast__icon{display:flex;align-items:center;justify-content:center;flex-shrink:0}.toast__message{flex:1;min-width:0}.toast--success{background:var(--color-success);color:#fff}.toast--error{background:var(--color-danger);color:#fff}.toast--warning{background:var(--color-warning);color:#fff}.toast--new{background:var(--text-primary);color:#fff}@keyframes toast-out{to{opacity:0;transform:translateY(8px) scale(.95)}}.how-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:var(--space-4);overflow:hidden}.how-card__toggle{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);cursor:pointer;-webkit-user-select:none;user-select:none;list-style:none}.how-card__toggle::-webkit-details-marker{display:none}.how-card__toggle-text{font-size:var(--text-sm);font-weight:var(--weight-bold);color:var(--text-primary);letter-spacing:-.01em}.how-card__chevron{color:var(--text-tertiary);transition:transform var(--duration-normal) var(--ease-out);flex-shrink:0}.how-card[open] .how-card__chevron{transform:rotate(180deg)}.how-card__body{display:flex;flex-direction:column;gap:var(--space-4);padding:0 var(--space-5) var(--space-5)}.how-card__step{display:flex;align-items:flex-start;gap:var(--space-3)}.how-card__num{width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--color-primary);color:var(--color-primary-text);font-family:var(--font-mono);font-size:var(--text-xs);font-weight:var(--weight-bold);border-radius:50%;line-height:1}.how-card__step-title{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text-primary);line-height:1.3}.how-card__step-text{font-size:var(--text-xs);color:var(--text-secondary);line-height:1.5}.app-footer{border-top:1px solid var(--color-border);padding:var(--space-6) var(--space-4) calc(var(--space-8) + var(--safe-bottom))}.app-footer__inner{max-width:var(--feed-max-width);margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.app-footer__logo{height:28px;width:auto}.app-footer__links{display:flex;align-items:center;gap:var(--space-2)}.app-footer__pill{padding:var(--space-3) var(--space-4);min-height:44px;display:inline-flex;align-items:center;font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--text-secondary);background:var(--color-base);border:1px solid var(--color-border);border-radius:var(--radius-pill);transition:all var(--duration-fast)}.app-footer__pill:hover{color:var(--color-primary);border-color:var(--color-primary);background:var(--color-primary-dim)}.app-footer__disclaimer{font-size:.6875rem;color:var(--text-tertiary);line-height:1.5;text-align:center;max-width:280px;opacity:.7}.skeleton{display:inline-block;width:28px;height:1.1em;background:linear-gradient(90deg,var(--color-border) 25%,var(--color-base) 50%,var(--color-border) 75%);background-size:200% 100%;border-radius:4px;vertical-align:middle}.voucher-card--skeleton{pointer-events:none}.skeleton--img{width:100%;aspect-ratio:8/5;border-radius:var(--radius-md);background:var(--color-border)}.skeleton--text{display:inline-block;height:14px;border-radius:4px;background:var(--color-border)}.skeleton--bar{width:100%;height:36px;border-radius:var(--radius-md);background:var(--color-border);margin-top:var(--space-3)}[class*=skeleton]{animation:shimmer 1.5s ease-in-out infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.fullscreen-barcode{position:fixed;top:0;right:0;bottom:0;left:0;z-index:250;background:#000000eb;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s var(--ease-out)}.fullscreen-barcode[hidden]{display:none}.fullscreen-barcode.visible{opacity:1}.fullscreen-barcode__close{position:absolute;top:var(--space-5);right:var(--space-5);width:44px;height:44px;display:flex;align-items:center;justify-content:center;color:#ffffffb3;border-radius:50%;transition:color var(--duration-fast),background var(--duration-fast);z-index:1}.fullscreen-barcode__close:hover{color:#fff;background:#ffffff1a}.fullscreen-barcode__content{display:flex;flex-direction:column;align-items:center;gap:var(--space-5)}.fullscreen-barcode__content canvas{max-width:280px;max-height:280px;width:100%;height:auto;background:#fff;border-radius:var(--radius-md);padding:var(--space-5)}.fullscreen-barcode__number{font-family:var(--font-mono);font-size:var(--text-lg);font-weight:var(--weight-bold);color:#ffffffe6;letter-spacing:.06em}@media(min-width:640px){.sheet{bottom:auto;top:50%;left:50%;right:auto;max-width:480px;width:calc(100% - var(--space-8));border-radius:var(--radius-xl);transform:translate(-50%,-50%) scale(.95);opacity:0;transition:transform var(--duration-slow) var(--ease-out),opacity var(--duration-slow) var(--ease-out)}.sheet.visible{transform:translate(-50%,-50%) scale(1);opacity:1}}.offline-banner{position:fixed;top:0;left:0;right:0;z-index:200;background:var(--text-primary);color:var(--text-inverse);text-align:center;padding:var(--space-2) var(--space-4);font-size:var(--text-xs);font-weight:var(--weight-semibold);transform:translateY(-100%);transition:transform var(--duration-normal) var(--ease-out)}.offline-banner--visible{transform:translateY(0)}.install-banner{display:flex;align-items:center;gap:var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);margin-bottom:var(--space-4)}.install-banner[hidden]{display:none}.install-banner__text{flex:1;font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text-primary)}.install-banner__btn{background:var(--color-primary);color:var(--text-inverse);border:none;border-radius:var(--radius-pill);padding:var(--space-2) var(--space-4);font-size:var(--text-xs);font-weight:var(--weight-semibold);cursor:pointer;white-space:nowrap;min-height:44px;display:flex;align-items:center;transition:background var(--duration-fast)}.install-banner__btn:hover{background:var(--color-primary-hover)}.install-banner__close{width:44px;height:44px;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);flex-shrink:0;border-radius:50%;transition:background var(--duration-fast)}.install-banner__close:hover{background:var(--color-base)}.avatar{display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--color-primary-dim);color:var(--color-primary);font-weight:var(--weight-bold);text-transform:uppercase;line-height:1}.avatar--sm{width:32px;height:32px;font-size:var(--text-sm)}.avatar--lg{width:64px;height:64px;font-size:var(--text-2xl)}.app-header__avatar{position:absolute;right:var(--space-4);top:50%;transform:translateY(-50%);text-decoration:none}.app-header__avatar[hidden]{display:none}.app-header__sign-in{position:absolute;right:var(--space-4);top:50%;transform:translateY(-50%);background:var(--color-primary-dim);color:var(--color-primary);border:none;border-radius:var(--radius-pill);padding:var(--space-2) var(--space-4);font-size:var(--text-xs);font-weight:var(--weight-semibold);cursor:pointer;min-height:36px;transition:background var(--duration-fast),color var(--duration-fast)}.app-header__sign-in:hover{background:var(--color-primary);color:var(--text-inverse)}.app-header__sign-in:disabled{opacity:.6;cursor:default}.app-header__sign-in[hidden]{display:none}.signin-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#0000004d;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:var(--space-4);opacity:0;transition:opacity var(--duration-normal) var(--ease-out)}.signin-backdrop[hidden]{display:none}.signin-backdrop--visible{opacity:1}.signin-modal{background:var(--color-surface);border-radius:var(--radius-xl);padding:var(--space-8) var(--space-6);width:100%;max-width:360px;position:relative;box-shadow:var(--shadow-lg);transform:scale(.95) translateY(8px);transition:transform var(--duration-normal) var(--ease-out)}.signin-backdrop--visible .signin-modal{transform:scale(1) translateY(0)}.signin-modal__close{position:absolute;top:var(--space-4);right:var(--space-4);width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);border-radius:50%;transition:background var(--duration-fast),color var(--duration-fast)}.signin-modal__close:hover{background:var(--color-base);color:var(--text-primary)}.signin-modal__title{font-size:var(--text-xl);font-weight:var(--weight-extrabold);color:var(--text-primary);letter-spacing:-.02em;margin-bottom:var(--space-2)}.signin-modal__text{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5;margin-bottom:var(--space-5)}.signin-modal__field{margin-bottom:var(--space-3)}.signin-modal__field[hidden]{display:none}.signin-modal__sent{display:flex;align-items:center;justify-content:center;gap:var(--space-2);color:var(--color-success);font-size:var(--text-sm);font-weight:var(--weight-semibold);padding:var(--space-4) 0;animation:pop var(--duration-normal) var(--ease-out)}.signin-modal__sent[hidden]{display:none}.signin-modal__error{font-size:var(--text-xs);color:var(--color-danger);font-weight:var(--weight-medium);margin-top:var(--space-2)}.signin-modal__error[hidden]{display:none}.text-input--error{border-color:var(--color-danger);box-shadow:0 0 0 3px var(--color-danger-dim)}.app-header__back{position:absolute;left:var(--space-4);top:50%;transform:translateY(-50%);width:44px;height:44px;display:flex;align-items:center;justify-content:center;color:var(--text-primary);border-radius:50%;transition:background var(--duration-fast)}.app-header__back:hover{background:var(--color-base)}.profile-page{max-width:var(--feed-max-width);margin:0 auto;padding:calc(var(--header-height) + var(--space-6)) var(--space-4) var(--space-12);display:flex;flex-direction:column;gap:var(--space-4)}.profile-page__loading{display:flex;justify-content:center;padding:var(--space-12) 0}.profile-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:var(--space-6);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.profile-card__email{font-size:var(--text-sm);color:var(--text-secondary)}.level-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5)}.level-card__header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3)}.level-card__emoji{font-size:var(--text-2xl);line-height:1}.level-card__name{font-size:var(--text-lg);font-weight:var(--weight-extrabold);color:var(--text-primary);letter-spacing:-.02em}.level-card__progress{display:flex;flex-direction:column;gap:var(--space-2)}.level-card__bar{height:8px;background:var(--color-base);border-radius:var(--radius-pill);overflow:hidden}.level-card__fill{height:100%;background:var(--color-primary);border-radius:var(--radius-pill);transition:width var(--duration-slow) var(--ease-out)}.level-card__next{font-size:var(--text-xs);color:var(--text-tertiary);font-weight:var(--weight-medium)}.level-card__max{font-size:var(--text-sm);color:var(--color-success);font-weight:var(--weight-semibold)}.profile-stats{display:flex;align-items:center;justify-content:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5)}.profile-stats__item{display:flex;flex-direction:column;align-items:center;flex:1;gap:2px}.profile-stats__value{font-family:var(--font-mono);font-size:var(--text-2xl);font-weight:var(--weight-extrabold);color:var(--text-primary);line-height:1}.profile-stats__label{font-size:.6875rem;font-weight:var(--weight-medium);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em}.profile-stats__divider{width:1px;height:28px;background:var(--color-border-strong);flex-shrink:0}.milestones{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5)}.milestones__title{font-size:var(--text-sm);font-weight:var(--weight-bold);color:var(--text-primary);margin-bottom:var(--space-3)}.milestones__list{display:flex;flex-direction:column;gap:var(--space-2)}.milestone{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--color-base);border-radius:var(--radius-sm);opacity:.5;transition:opacity .3s}.milestone--earned{opacity:1;background:var(--color-success-dim)}.milestone__emoji{font-size:22px;line-height:1;flex-shrink:0}.milestone__body{flex:1;min-width:0}.milestone__label{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text-primary);display:block;margin-bottom:var(--space-1)}.milestone__progress{display:flex;align-items:center;gap:var(--space-2)}.milestone__bar{flex:1;height:5px;background:var(--color-border-strong);border-radius:3px;overflow:hidden}.milestone__fill{height:100%;background:var(--color-success);border-radius:3px;transition:width .6s ease}.milestone--earned .milestone__fill{background:var(--color-success)}.milestone__count{font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--text-tertiary);flex-shrink:0;min-width:36px;text-align:right}.milestone--earned .milestone__count{color:var(--color-success);font-weight:var(--weight-bold)}.profile-signout{text-align:center;padding:var(--space-6) 0 var(--space-4);display:flex;flex-direction:column;align-items:center;gap:var(--space-3)}.profile-signout__email{font-size:var(--text-sm);color:var(--text-tertiary)}.my-drops{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5)}.my-drops__title{font-size:var(--text-sm);font-weight:var(--weight-bold);color:var(--text-primary);margin-bottom:var(--space-3)}.my-drops__empty{font-size:var(--text-sm);color:var(--text-tertiary);text-align:center;padding:var(--space-4)}.my-drops__list{display:flex;flex-direction:column;gap:var(--space-2)}.my-drop-card{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);background:var(--color-base);border-radius:var(--radius-sm)}.my-drop-card__info{display:flex;flex-direction:column;gap:2px;min-width:0}.my-drop-card__deal{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.my-drop-card__barcode{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary);letter-spacing:.04em}.my-drop-card__views{display:flex;align-items:center;gap:4px;font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text-secondary);flex-shrink:0}.my-drop-card__views svg{opacity:.5}.leaderboard{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);margin-bottom:var(--space-4)}.leaderboard:empty{display:none}.leaderboard__title{font-size:var(--text-sm);font-weight:var(--weight-bold);color:var(--text-primary);margin-bottom:var(--space-3)}.leaderboard__list{display:flex;flex-direction:column;gap:var(--space-2);max-height:200px;overflow-y:auto}.leaderboard__row{display:flex;align-items:baseline;gap:var(--space-3);padding:var(--space-2) 0}.leaderboard__rank{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:var(--weight-bold);color:var(--text-tertiary);width:18px;text-align:center;flex-shrink:0}.leaderboard__name{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text-primary);flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.leaderboard__you{display:inline-block;font-size:var(--text-xs);font-weight:var(--weight-bold);color:var(--color-primary);background:var(--color-primary-dim);padding:1px 8px;border-radius:var(--radius-pill);margin-left:var(--space-2);vertical-align:baseline}.leaderboard__stat{font-size:var(--text-xs);color:var(--text-tertiary);font-weight:var(--weight-medium);flex-shrink:0}.auth-prompt{margin-top:var(--space-5);padding:var(--space-5);background:var(--color-base);border:1px solid var(--color-border);border-radius:var(--radius-md);text-align:center}.auth-prompt__title{font-size:var(--text-base);font-weight:var(--weight-bold);color:var(--text-primary);margin-bottom:var(--space-1)}.auth-prompt__text{font-size:var(--text-xs);color:var(--text-secondary);margin-bottom:var(--space-4);line-height:1.5}.auth-prompt__field{display:flex;gap:var(--space-2);margin-bottom:var(--space-3)}.auth-prompt__field .text-input{flex:1}.auth-prompt__dismiss{font-size:var(--text-xs);color:var(--text-tertiary);cursor:pointer;background:none;border:none;padding:var(--space-2);min-height:44px;display:inline-flex;align-items:center}.auth-prompt__dismiss:hover{color:var(--text-secondary)}.auth-prompt__sent{color:var(--color-success);font-size:var(--text-sm);font-weight:var(--weight-semibold);padding:var(--space-3) 0}.auth-gate-icon{width:64px;height:64px;background:var(--color-primary-dim);color:var(--color-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-5)}.auth-gate__field{display:flex;gap:var(--space-2);margin-top:var(--space-5);max-width:320px;margin-left:auto;margin-right:auto}.auth-gate__field .text-input{flex:1}.voucher-card--mine{position:relative}.voucher-card__mine-badge{position:absolute;top:var(--space-3);right:var(--space-3);padding:2px var(--space-3);background:var(--color-primary);color:var(--text-inverse);font-size:var(--text-xs);font-weight:var(--weight-semibold);border-radius:var(--radius-pill);z-index:1}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
