:root{--bg: #F7F5F0;--card-bg: #ffffff;--primary: #3F3A60;--primary-light: #6B6590;--primary-dark: #2D2945;--accent: #C4856A;--accent-light: #D9A893;--text: #3A3A3A;--text-secondary: #9B9690;--success: #7A9E7E;--rating-color: #C4956A;--border: #E8E4DE;--shadow: 0 2px 16px rgba(63, 58, 96, .06);--shadow-lg: 0 8px 40px rgba(63, 58, 96, .1);--f7-theme-color: #3F3A60;--f7-theme-color-rgb: 63, 58, 96;--f7-theme-color-shade: #2D2945;--f7-theme-color-tint: #6B6590;--f7-page-bg-color: var(--bg);--f7-bars-bg-color: var(--card-bg);--f7-bars-text-color: var(--text);--f7-navbar-shadow-image: none;--f7-navbar-border-color: var(--border)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased;letter-spacing:-.01em;font-weight:400;line-height:1.5;touch-action:pan-x pan-y}.navbar{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#f7f5f0d9!important}.page-content{background:var(--bg)!important}.pull-indicator{display:flex;align-items:flex-end;justify-content:center;overflow:hidden}.pull-indicator--releasing{transition:height .25s ease-out}.pull-indicator__spinner{font-size:22px;color:var(--primary);transition:transform .15s}.pull-indicator__spinner--active{animation:pullSpin .8s linear infinite}@keyframes pullSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.scan-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;display:flex;align-items:flex-end;justify-content:center;padding:16px 16px 32px;background:#3a3a3a33;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);opacity:0;pointer-events:none;transition:opacity .35s ease;will-change:opacity}.scan-overlay.visible{opacity:1;pointer-events:auto;overscroll-behavior:contain}.scan-card{position:relative;width:100%;max-width:420px;max-height:85vh;overflow:hidden;background:transparent;border-radius:20px;transform:translate3d(0,100%,0);transition:transform .45s cubic-bezier(.22,1,.36,1);will-change:transform}.scan-card__scroll{max-height:85vh;overflow-y:scroll;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;touch-action:pan-y;scrollbar-width:none;width:calc(100% + 20px);padding-right:20px}.scan-card::-webkit-scrollbar,.scan-card__scroll::-webkit-scrollbar{display:none}.scan-overlay.visible .scan-card{transform:translateZ(0)}.scan-card__close{position:sticky;top:10px;float:right;margin:10px 10px -46px 0;z-index:10;width:36px;height:36px;border-radius:50%;border:none;background:#3a3a3a73;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,transform .15s;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.scan-card__close:hover{background:#3a3a3aa6}.scan-card__close:active{transform:scale(.9)}.scan-card__image{width:100%;aspect-ratio:4 / 3;object-fit:cover;border-radius:20px 20px 0 0;display:block}.scan-card__image-wrap{position:relative}.scan-card__bgg-thumb{position:absolute;bottom:-20px;right:16px;width:56px;height:56px;border-radius:14px;object-fit:cover;border:3px solid var(--card-bg);box-shadow:0 2px 12px #0000001f;background:var(--card-bg)}.scan-card__body{padding:24px 20px 20px;background:var(--card-bg);border-radius:0 0 20px 20px}.scan-fab{position:fixed;bottom:32px;left:50%;transform:translate(-50%) scale(1);z-index:400;width:60px;height:60px;border-radius:50%;border:none;background:var(--primary);color:#fff;font-size:28px;box-shadow:0 4px 20px #3f3a6059;cursor:pointer;transition:transform .3s cubic-bezier(.22,1,.36,1),opacity .3s ease;display:flex;align-items:center;justify-content:center;will-change:transform}.scan-fab:active{transform:translate(-50%) scale(.92)}.scan-fab.hidden{transform:translate(-50%) scale(0);opacity:0;pointer-events:none}.upload-btn{background:var(--card-bg);border:1px solid var(--border);color:var(--primary);border-radius:12px;padding:8px 18px;font-size:14px;font-weight:500;font-family:inherit;cursor:pointer;transition:background .2s,border-color .2s,transform .15s;will-change:transform}.upload-btn:hover{background:#3f3a600f;border-color:var(--primary-light);transform:translateY(-1px)}.loader-dots{display:flex;gap:8px;align-items:center;justify-content:center;padding:20px 0}.loader-dots span{width:8px;height:8px;border-radius:50%;background:var(--primary-light);animation:dotPulse 1.2s ease-in-out infinite}.loader-dots span:nth-child(2){animation-delay:.15s}.loader-dots span:nth-child(3){animation-delay:.3s}@keyframes dotPulse{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}.loader-text{text-align:center;color:var(--text-secondary);font-size:13px;font-weight:300;margin-top:4px;letter-spacing:.02em}.stagger-in{opacity:0;animation:staggerSlideUp .5s cubic-bezier(.25,.1,.25,1) both;animation-delay:var(--stagger, 0ms);will-change:transform,opacity}@keyframes staggerSlideUp{0%{opacity:0;transform:translate3d(0,8px,0)}to{opacity:1;transform:translateZ(0)}}.game-result__title{font-size:19px;font-weight:600;text-align:center;margin-bottom:16px;color:var(--text);letter-spacing:-.02em;line-height:1.3}.game-result__subtitle{font-size:13px;font-weight:400;color:var(--text-secondary);margin-top:4px;letter-spacing:0}.game-result__rating-ring{width:72px;height:72px;border-radius:50%;background:var(--ring-color, var(--rating-color));display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.game-result__rating{font-size:24px;font-weight:700;color:#fff;line-height:1}.game-result__links{display:flex;gap:8px;justify-content:center;margin-bottom:20px;min-height:38px}.game-result__pill{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:24px;font-size:13px;font-weight:500;font-family:inherit;text-decoration:none;transition:transform .15s,box-shadow .15s;will-change:transform;cursor:pointer;border:none}.game-result__pill:active{transform:scale(.96)}.game-result__pill--bgg{background:var(--primary);color:#fff;box-shadow:0 2px 8px #3f3a6040}.game-result__pill--bgg:hover{box-shadow:0 4px 14px #3f3a6059;transform:translateY(-1px)}.game-result__pill--ceneo{background:var(--accent);color:#fff;box-shadow:0 2px 8px #c4856a40}.game-result__pill--ceneo:hover{box-shadow:0 4px 14px #c4856a59;transform:translateY(-1px)}.game-result__pill--loading{opacity:.7;cursor:default}.game-result__pill--loading .price-spinner{border-top-color:#fff}.game-result__pill--empty{background:var(--border);color:var(--text-secondary);box-shadow:none;cursor:default}.game-result__row{display:flex;justify-content:space-between;align-items:center;padding:11px 0;border-bottom:1px dashed var(--border);font-size:14px}.game-result__row:last-child{border-bottom:0}.game-result__label{color:var(--text-secondary);font-weight:400;font-size:13px}.game-result__value{font-weight:600;color:var(--text)}.game-result__mechanics-section{margin-bottom:12px;padding-top:11px;border-top:1px dashed var(--border)}.game-result__mechanics{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}.game-result__chip{background:#3f3a6014;color:var(--primary-dark);border-radius:20px;padding:5px 12px;font-size:12px;font-weight:500}.game-result__detected{text-align:center;margin-top:12px;font-size:12px;color:var(--text-secondary);font-weight:300}.game-result__badge--image{display:inline-block;padding:4px 10px;border-radius:8px;background:#4caf5026;color:#4caf50;font-weight:500;font-size:13px}.scan-another-btn{display:block;width:100%;margin-top:20px;padding:14px;border:none;border-radius:14px;background:var(--primary);color:#fff;font-size:15px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .2s,transform .15s;will-change:transform}.scan-another-btn:hover{background:var(--primary-dark);transform:translateY(-1px)}.scan-another-btn:active{transform:scale(.98)}.scan-error{text-align:center;padding:16px 0;color:var(--accent);font-size:14px}.scan-error__retry{display:inline-block;margin-top:12px;padding:10px 24px;border:1px solid var(--accent);border-radius:12px;background:none;color:var(--accent);font-size:14px;font-family:inherit;cursor:pointer;transition:background .2s,transform .15s}.scan-error__retry:hover{background:#c4856a14}.scan-error__retry:active{transform:scale(.97)}.hero{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:60px 24px 120px;min-height:calc(100vh - 56px)}.hero__emoji{font-size:52px;margin-bottom:16px;animation:gentleFloat 3s ease-in-out infinite}@keyframes gentleFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.hero__title{font-size:26px;font-weight:600;color:var(--text);margin-bottom:8px;letter-spacing:-.02em}.hero__subtitle{font-size:15px;color:var(--text-secondary);max-width:280px;font-weight:300;line-height:1.5}.auth-page{max-width:400px;margin:0 auto;padding:48px 20px}.auth-page__title{font-size:26px;font-weight:600;text-align:center;margin-bottom:32px;color:var(--text);letter-spacing:-.02em}.auth-page__form{display:flex;flex-direction:column;gap:14px}.auth-page__input{padding:14px 16px;border-radius:12px;border:1px solid var(--border);background:var(--card-bg);color:var(--text);font-size:16px;font-family:inherit;outline:none;transition:border-color .2s,box-shadow .2s}.auth-page__input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #3f3a601f}.auth-page__input::placeholder{color:var(--text-secondary);font-weight:300}.auth-page__btn{padding:14px;border:none;border-radius:12px;background:var(--primary);color:#fff;font-size:16px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .2s,transform .15s;will-change:transform}.auth-page__btn:hover{background:var(--primary-dark);transform:translateY(-1px)}.auth-page__btn:active{transform:scale(.98)}.auth-page__btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-page__error{background:#c4856a1a;color:var(--accent);padding:12px;border-radius:10px;text-align:center;font-size:14px}.auth-page__link{text-align:center;margin-top:20px;color:var(--text-secondary);font-size:14px}.auth-page__link a{color:var(--primary);text-decoration:none;font-weight:500}.webcam-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:600;background:#3a3a3a80;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;animation:fadeIn .25s ease}.webcam-overlay video{max-width:min(90vw,560px);max-height:60vh;border-radius:16px;box-shadow:var(--shadow-lg)}.webcam-overlay__actions{display:flex;gap:12px}.webcam-snap-btn{width:64px;height:64px;border-radius:50%;border:4px solid #fff;background:var(--primary);color:#fff;font-size:24px;cursor:pointer;box-shadow:0 4px 16px #00000026;display:flex;align-items:center;justify-content:center;transition:transform .15s}.webcam-snap-btn:active{transform:scale(.92)}.webcam-cancel-btn{width:48px;height:48px;border-radius:50%;border:none;background:#fff3;color:#fff;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.webcam-cancel-btn:hover{background:#ffffff4d}.app-navbar{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;background:#f7f5f0e6;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:200}.app-navbar__logo{display:flex;align-items:center;text-decoration:none}.app-navbar__logo img{width:40px;height:40px;border-radius:50%;object-fit:cover}.app-navbar__links{display:flex;gap:8px;align-items:center}.app-navbar__link{color:var(--text-secondary);text-decoration:none;font-size:14px;font-weight:500;transition:color .2s}.app-navbar__link:hover{color:var(--primary)}.app-navbar__icon-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s}.app-navbar__icon-btn:hover{background:#3f3a600f;color:var(--primary)}@keyframes slideUp{0%{opacity:0;transform:translate3d(0,16px,0)}to{opacity:1;transform:translateZ(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.price-spinner{display:inline-block;width:14px;height:14px;border:2px solid transparent;border-top-color:var(--primary);border-radius:50%;animation:priceSpin .7s linear infinite;vertical-align:middle}@keyframes priceSpin{to{transform:rotate(360deg)}}.material-symbols-outlined{font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24;vertical-align:middle;line-height:1}.scan-list{max-width:480px;margin:0 auto;padding:16px 16px 100px;display:flex;flex-direction:column;gap:10px}.swipeable{position:relative;overflow:hidden;border-radius:16px}.swipeable-bg{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;background:var(--accent);border-radius:16px;opacity:0;padding:0 24px}.swipeable-bg__icon{color:#fff;display:flex;align-items:center}.swipeable-bg__icon--left{margin-right:auto}.swipeable-bg__icon--right{margin-left:auto}.swipeable-inner{position:relative;z-index:1;will-change:transform}.scan-list-item{display:flex;align-items:center;gap:14px;padding:10px;background:var(--card-bg);border-radius:16px;box-shadow:var(--shadow);transition:transform .15s;will-change:transform}.scan-list-item:active{transform:scale(.98)}.scan-list-item--enter{animation:listItemIn .5s cubic-bezier(.22,1,.36,1) forwards}.scan-list-item--pending{opacity:.65}.scan-list-item__name--loading{color:var(--text-secondary);font-style:italic}.scan-list-item__name--error{color:var(--accent)}@keyframes listItemIn{0%{opacity:0;transform:translate3d(40px,0,0) scale(.95)}to{opacity:1;transform:translateZ(0) scale(1)}}.scan-list-item__thumb-wrap{width:56px;height:56px;border-radius:12px;flex-shrink:0;overflow:hidden;background:linear-gradient(90deg,#e8e6e1 25%,#f2f0ec,#e8e6e1 75%);background-size:200% 100%;animation:shimmer 1.4s ease-in-out infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.scan-list-item__thumb{width:56px;height:56px;border-radius:12px;object-fit:cover;flex-shrink:0;opacity:0;transition:opacity .3s ease}.scan-list-item__thumb--loaded{opacity:1}.scan-list-item__info{flex:1;min-width:0}.scan-list-item__name{font-weight:600;font-size:15px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.scan-list-item__meta{font-size:12px;color:var(--text-secondary);margin-top:2px;font-weight:300}.scan-list-item__rating{font-size:22px;font-weight:700;color:var(--rating-color);flex-shrink:0;min-width:40px;text-align:right}.scan-list-item__price{font-size:13px;font-weight:600;color:var(--success);flex-shrink:0;white-space:nowrap;animation:fadeIn .4s ease}.scan-list-item__price--empty{color:var(--text-secondary);font-weight:400}.hero--compact{min-height:auto;padding:32px 24px 24px}.hero--compact .hero__emoji{font-size:36px;margin-bottom:8px;animation:none}.hero--compact .hero__title{font-size:20px}.hero--compact .hero__subtitle{font-size:13px}.game-result__alternatives{margin-top:16px;padding-top:12px;border-top:1px dashed var(--border);text-align:center}.game-result__alternatives-label{font-size:12px;color:var(--text-secondary);margin-bottom:8px;font-weight:300}.game-result__alternatives-list{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}.game-result__alt-chip{background:transparent;border:1.5px solid var(--accent-light);border-radius:20px;padding:5px 14px;font-size:12px;font-weight:500;font-family:inherit;color:var(--accent);cursor:pointer;transition:background .15s,color .15s,transform .15s;will-change:transform}.game-result__alt-chip:hover{background:var(--accent);color:#fff;border-color:var(--accent);transform:translateY(-1px)}.game-result__alt-chip:active{transform:scale(.96)}.admin-page{max-width:720px;margin:0 auto;padding:16px}.admin-tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:16px}.admin-tabs__btn{flex:1;padding:10px 0;font-size:14px;font-weight:600;font-family:inherit;color:var(--text-secondary);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;transition:color .15s,border-color .15s}.admin-tabs__btn--active{color:var(--primary);border-bottom-color:var(--primary)}.admin-tab-content{min-height:200px}.admin-error{color:var(--accent)}.admin-list{display:flex;flex-direction:column;gap:12px}.admin-card{background:var(--card-bg);border-radius:14px;box-shadow:var(--shadow);padding:16px}.admin-card--moderated{opacity:.7}.admin-card__header{display:flex;gap:12px;align-items:flex-start;margin-bottom:10px}.admin-card__image{width:64px;height:64px;object-fit:cover;border-radius:10px;flex-shrink:0;cursor:pointer;transition:opacity .15s}.admin-card__image:active{opacity:.7}.admin-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:600;display:flex;align-items:center;justify-content:center;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);cursor:pointer;animation:fadeIn .2s ease}.admin-lightbox__img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:12px}.admin-card__header-text{display:flex;flex-direction:column;gap:4px}.admin-card__date{font-size:12px;color:var(--text-secondary);font-weight:300}.admin-card__badge{font-size:11px;padding:2px 8px;border-radius:10px;font-weight:600}.admin-card__badge--accepted{background:#7a9e7e1f;color:#5e8c61}.admin-card__badge--rejected{background:#c4856a1f;color:#a03030}.admin-card__body{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.admin-card__row{display:flex;justify-content:space-between;font-size:13px}.admin-card__label{color:var(--text-secondary);flex-shrink:0;margin-right:8px}.admin-card__value{color:var(--text);text-align:right}.admin-card__ocr{font-family:SF Mono,Fira Code,monospace;font-size:11px;word-break:break-all}.admin-card__selected{font-weight:600;color:var(--primary)}.admin-card__actions{display:flex;gap:8px;justify-content:flex-end}.admin-card__btn{border:none;border-radius:10px;padding:6px 16px;font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:opacity .15s,transform .15s;will-change:transform}.admin-card__btn:hover{opacity:.85;transform:translateY(-1px)}.admin-card__btn:active{transform:scale(.97)}.admin-card__btn--accept{background:var(--success);color:#fff}.admin-card__btn--reject{background:var(--accent);color:#fff}.pipeline{display:flex;flex-direction:column;gap:12px}.pipeline__card{background:var(--card-bg);border-radius:14px;box-shadow:var(--shadow);padding:16px}.pipeline__card-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:12px;letter-spacing:-.01em}.pipeline__stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.pipeline__stat{display:flex;flex-direction:column;align-items:center;gap:2px}.pipeline__stat-value{font-size:20px;font-weight:700;color:var(--primary)}.pipeline__stat-label{font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:400}.pipeline__actions{display:flex;gap:8px;flex-wrap:wrap}.pipeline__btn{flex:1;min-width:90px;padding:8px 12px;font-size:13px;font-weight:600;font-family:inherit;color:var(--primary);background:#3f3a600f;border:1px solid var(--border);border-radius:10px;cursor:pointer;transition:background .15s,color .15s,transform .15s;will-change:transform}.pipeline__btn:hover{background:var(--primary);color:#fff;transform:translateY(-1px)}.pipeline__btn:active{transform:scale(.97)}.pipeline__action-msg{margin-top:8px;font-size:12px;color:var(--text-secondary);text-align:center}.pipeline__empty{font-size:13px;color:var(--text-secondary)}.pipeline__enrichment{padding:10px 0;border-bottom:1px solid var(--border)}.pipeline__enrichment:last-child{border-bottom:none}.pipeline__enrichment--running{border-left:3px solid var(--success);padding-left:10px}.pipeline__enrichment-header{display:flex;justify-content:space-between;font-size:13px;font-weight:600;color:var(--text);margin-bottom:4px}.pipeline__enrichment-time{font-weight:400;color:var(--text-secondary)}.pipeline__enrichment-details{display:flex;gap:12px;font-size:12px;color:var(--text-secondary)}.pipeline__enrichment-badge{display:inline-block;margin-top:4px;padding:2px 8px;font-size:11px;font-weight:600;background:#7a9e7e1f;color:#5e8c61;border-radius:10px}
