:root{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-card: #334155;--bg-slot: #1e293b;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--accent: #e53e3e;--accent-hover: #c53030;--accent-glow: rgba(229, 62, 62, .3);--success: #38a169;--warning: #ecc94b;--danger: #e53e3e;--border: #475569;--radius: 12px;--radius-sm: 8px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary);-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}input,select,textarea,button{font-family:inherit;font-size:1rem}img{max-width:100%;display:block}.loading-screen,.page-loading{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-secondary);font-size:1.1rem}.update-banner{position:fixed;top:0;left:0;right:0;z-index:9999;background:var(--accent);color:#fff;text-align:center;padding:10px 16px;font-size:.9rem;font-weight:600;cursor:pointer;animation:slideDown .3s ease}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.app-layout{display:flex;flex-direction:column;height:100%}.app-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border);flex-shrink:0}.logo{display:flex;align-items:center;gap:8px}.logo-icon{width:32px;height:32px;border-radius:6px}.logo span{font-size:1.5rem;font-weight:800;background:linear-gradient(135deg,#e53e3e,#ecc94b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.user-badge{background:var(--bg-card);padding:4px 12px;border-radius:20px;font-size:.85rem;color:var(--text-secondary)}.app-main{flex:1;overflow-y:auto;padding:16px;-webkit-overflow-scrolling:touch}.bottom-nav{display:flex;background:var(--bg-secondary);border-top:1px solid var(--border);flex-shrink:0;padding-bottom:env(safe-area-inset-bottom)}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;padding:8px 0;text-decoration:none;color:var(--text-muted);font-size:.7rem;gap:2px;transition:color .2s}.nav-item svg{width:22px;height:22px}.nav-item.active{color:var(--accent)}.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}.auth-card{width:100%;max-width:380px;background:var(--bg-secondary);border-radius:var(--radius);padding:32px 24px;text-align:center}.auth-icon{width:120px;height:120px;border-radius:24px;margin:0 auto 12px;display:block}.auth-logo{font-size:1.5rem;font-weight:800;margin-bottom:4px;background:linear-gradient(135deg,#e53e3e,#ecc94b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-subtitle{color:var(--text-secondary);margin-bottom:24px}.auth-toggle{display:flex;gap:0;margin-bottom:20px;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border)}.auth-toggle button{flex:1;padding:10px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;font-weight:600;transition:all .2s}.auth-toggle button.active{background:var(--accent);color:#fff}.auth-card form{display:flex;flex-direction:column;gap:12px}.auth-card input{padding:12px 16px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-primary);color:var(--text-primary);outline:none}.auth-card input:focus{border-color:var(--accent)}.auth-error{color:var(--danger);font-size:.85rem}.auth-divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:var(--text-muted);font-size:.85rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border)}.btn-hub-login{width:100%;padding:12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:transparent;color:var(--text-primary);font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:all .2s}.btn-hub-login:hover{border-color:var(--accent);color:var(--accent)}.btn-hub-login:disabled{opacity:.6;cursor:not-allowed}.btn-hub-login svg{width:20px;height:20px}.auth-links{margin-top:16px}.auth-links a{color:var(--accent);text-decoration:none;font-size:.9rem}.btn-primary{padding:12px 24px;border:none;border-radius:var(--radius-sm);background:var(--accent);color:#fff;font-weight:600;cursor:pointer;transition:background .2s}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-small{padding:6px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);background:transparent;color:var(--text-primary);font-size:.85rem;cursor:pointer;transition:all .2s}.btn-small:hover{border-color:var(--accent);color:var(--accent)}.btn-danger{padding:10px 20px;border:none;border-radius:var(--radius-sm);background:var(--danger);color:#fff;font-weight:600;cursor:pointer;width:100%}.btn-edit{padding:10px 20px;border:none;border-radius:var(--radius-sm);background:var(--accent);color:#fff;font-weight:600;cursor:pointer;width:100%}.btn-back,.btn-scan{background:none;border:none;color:var(--text-primary);cursor:pointer;padding:8px}.btn-back svg,.btn-scan svg{width:24px;height:24px}.btn-delete{position:absolute;top:8px;right:8px;background:#0009;border:none;border-radius:50%;padding:6px;cursor:pointer;color:var(--danger);opacity:0;transition:opacity .2s}.btn-delete svg{width:16px;height:16px}.binder-card:hover .btn-delete{opacity:1}.btn-delete-small{padding:4px 10px;border:1px solid var(--danger);border-radius:var(--radius-sm);background:transparent;color:var(--danger);font-size:.8rem;cursor:pointer}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.page-header h2{font-size:1.3rem}.binders-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.binder-card{position:relative;background:var(--bg-secondary);border-radius:var(--radius);overflow:hidden;text-decoration:none;color:inherit;transition:transform .2s,box-shadow .2s}.binder-card:active{transform:scale(.97)}.binder-photo{aspect-ratio:3/4;overflow:hidden;background:var(--bg-card)}.binder-photo img{width:100%;height:100%;object-fit:cover}.binder-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.binder-placeholder svg{width:48px;height:48px;color:var(--text-muted)}.binder-info{padding:10px 12px}.binder-info h3{font-size:.95rem;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.binder-meta{display:flex;justify-content:space-between;font-size:.8rem;color:var(--text-secondary)}.binder-value{color:var(--success);font-weight:600}.create-binder-form{background:var(--bg-secondary);border-radius:var(--radius);padding:16px;margin-bottom:16px;display:flex;flex-direction:column;gap:12px}.create-binder-form input,.create-binder-form select{padding:10px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-primary);color:var(--text-primary);outline:none}.create-binder-form input:focus{border-color:var(--accent)}.binder-photo-upload{aspect-ratio:3/4;max-height:200px;border:2px dashed var(--border);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;cursor:pointer;overflow:hidden;transition:border-color .2s}.binder-photo-upload:hover{border-color:var(--accent)}.binder-photo-upload img{width:100%;height:100%;object-fit:cover}.photo-placeholder{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-muted)}.photo-placeholder svg{width:40px;height:40px}.photo-placeholder span{font-size:.85rem}.form-row{display:flex;gap:12px}.form-row label{flex:1;display:flex;flex-direction:column;gap:4px;font-size:.85rem;color:var(--text-secondary)}.binder-view-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.binder-view-header h2{font-size:1.2rem}.binder-view-meta{font-size:.8rem;color:var(--text-secondary)}.binder-view-header .btn-scan{margin-left:auto}.binder-grid{display:grid;gap:8px;margin-bottom:16px}.binder-slot{aspect-ratio:63/88;border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;position:relative;transition:transform .15s,box-shadow .15s}.binder-slot:active{transform:scale(.95)}.binder-slot.empty{background:var(--bg-slot);border:2px dashed var(--border);display:flex;align-items:center;justify-content:center}.slot-empty-label{display:flex;flex-direction:column;align-items:center;color:var(--text-muted);gap:2px}.slot-empty-label span{font-size:1.5rem;font-weight:300}.slot-empty-label small{font-size:.65rem}.binder-slot.filled{background:var(--bg-card)}.binder-slot.filled img{width:100%;height:100%;object-fit:cover}.slot-variant{position:absolute;top:0;left:0;right:0;background:#000000b3;padding:2px 4px;font-size:.55rem;font-weight:700;letter-spacing:.5px;text-align:center;color:#fbbf24}.slot-variant.holofoil{color:#a78bfa}.slot-variant.reverseHolofoil{color:#34d399}.slot-price{position:absolute;bottom:0;left:0;right:0;background:#000000bf;padding:2px 6px;font-size:.7rem;color:var(--success);font-weight:600;text-align:center}.page-nav{display:flex;align-items:center;gap:8px;justify-content:center}.page-nav button{background:var(--bg-secondary);border:none;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:var(--text-primary);cursor:pointer}.page-nav button:disabled{opacity:.3;cursor:not-allowed}.page-nav button svg{width:18px;height:18px}.page-dots{display:flex;gap:4px;overflow-x:auto;padding:4px 0;-webkit-overflow-scrolling:touch}.page-dot{min-width:28px;height:28px;border-radius:50%;border:1px solid var(--border);background:transparent;color:var(--text-muted);font-size:.75rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.page-dot.active{background:var(--accent);border-color:var(--accent);color:#fff}.page-dot.has-cards{border-color:var(--success)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:flex-end;justify-content:center;z-index:100;padding:0}.card-search-modal,.card-detail-modal{background:var(--bg-secondary);border-radius:var(--radius) var(--radius) 0 0;width:100%;max-width:500px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid var(--border)}.modal-header h3{font-size:1rem}.modal-close{background:none;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;padding:0 4px}.search-toggle{display:flex;padding:12px 16px 0;gap:0}.search-toggle button{flex:1;padding:8px;border:1px solid var(--border);background:transparent;color:var(--text-secondary);cursor:pointer;font-size:.85rem}.search-toggle button:first-child{border-radius:var(--radius-sm) 0 0 var(--radius-sm)}.search-toggle button:last-child{border-radius:0 var(--radius-sm) var(--radius-sm) 0}.search-toggle button.active{background:var(--accent);border-color:var(--accent);color:#fff}.search-form{display:flex;gap:8px;padding:12px 16px}.search-form input{flex:1;padding:10px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-primary);color:var(--text-primary);outline:none}.search-form input:focus{border-color:var(--accent)}.search-form .btn-primary{padding:10px 16px;white-space:nowrap}.search-scan{padding:12px 16px}.scan-video-wrapper{position:relative;border-radius:8px;overflow:hidden}.scan-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:flex-end;justify-content:center;padding-bottom:15%}.scan-focus-box{width:70%;height:50px;border:3px solid var(--accent);border-radius:8px;box-shadow:0 0 0 9999px #0006,0 0 20px var(--accent-glow);display:flex;align-items:center;justify-content:center}.scan-focus-label{font-size:.75rem;color:var(--accent);font-weight:600;text-shadow:0 1px 3px rgba(0,0,0,.8)}.scan-capture-area{text-align:center;margin-top:10px}.scan-hint-text{font-size:.8rem;color:var(--text-muted);margin-bottom:10px}.search-scan .btn-capture{margin-top:8px}.condition-select{display:flex;align-items:center;gap:8px;padding:0 16px 8px;font-size:.85rem;color:var(--text-secondary)}.condition-select select{padding:6px 10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-primary);color:var(--text-primary);outline:none}.search-results{flex:1;overflow-y:auto;padding:0 16px 16px;-webkit-overflow-scrolling:touch}.search-hint{color:var(--text-muted);text-align:center;padding:24px 0}.search-result-card{display:flex;align-items:center;gap:12px;padding:10px;border-radius:var(--radius-sm);background:var(--bg-card);margin-bottom:8px}.search-result-card img{width:50px;height:70px;object-fit:cover;border-radius:4px}.result-info{flex:1;display:flex;flex-direction:column;gap:2px}.result-info strong{font-size:.9rem}.result-info span{font-size:.75rem;color:var(--text-secondary)}.result-rarity{color:var(--warning)!important}.result-price{color:var(--success)!important;font-weight:600}.result-variant{color:var(--accent)!important;text-transform:capitalize}.variant-select{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--bg-card);border-radius:6px;padding:4px 8px;font-size:.75rem;width:100%;margin-top:2px}.btn-add{width:36px;height:36px;border-radius:50%;border:none;background:var(--accent);color:#fff;font-size:1.2rem;cursor:pointer;flex-shrink:0}.btn-add:disabled{opacity:.5}.search-hint-link{color:var(--accent);cursor:pointer;text-decoration:underline}.manual-entry-form{display:flex;flex-direction:column;gap:10px;padding:12px 0}.manual-entry-form input{padding:10px 12px;border-radius:8px;border:1px solid var(--bg-card);background:var(--bg-primary);color:var(--text-primary);font-size:.9rem}.manual-entry-form .search-hint{font-size:.8rem;color:var(--text-muted);margin:0;text-align:center}.card-detail-modal{flex-direction:row;align-items:flex-start;border-radius:var(--radius);max-height:80vh;position:relative;margin:auto}.card-detail-modal>img{width:45%;height:auto;border-radius:var(--radius) 0 0 var(--radius)}.card-detail-info{flex:1;padding:20px;overflow-y:auto}.card-detail-info h3{font-size:1.2rem;margin-bottom:8px}.card-set{color:var(--text-secondary);font-size:.85rem}.card-rarity{color:var(--warning);font-size:.85rem}.card-variant{color:var(--accent);font-size:.85rem;text-transform:capitalize}.card-condition{color:var(--text-muted);font-size:.85rem;margin-bottom:12px}.card-edit-form{display:flex;flex-direction:column;gap:10px;margin-bottom:12px}.card-edit-form label{display:flex;flex-direction:column;gap:4px;font-size:.8rem;color:var(--text-secondary)}.card-edit-form select{padding:8px 10px;border-radius:6px;border:1px solid var(--bg-card);background:var(--bg-primary);color:var(--text-primary);font-size:.85rem}.card-edit-actions{display:flex;gap:8px}.card-edit-actions .btn-primary{flex:1}.card-edit-actions .btn-small{flex:0}.card-detail-buttons{display:flex;flex-direction:column;gap:8px}.card-prices{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px}.card-prices div{background:var(--bg-primary);padding:8px;border-radius:var(--radius-sm);display:flex;flex-direction:column;align-items:center}.card-prices span{font-size:.7rem;color:var(--text-muted)}.card-prices strong{color:var(--success)}.price-chart{margin:12px 0}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.chart-title{font-size:.85rem;font-weight:600}.chart-change{font-size:.85rem;font-weight:700}.chart-change.up{color:var(--success)}.chart-change.down{color:var(--danger)}.chart-canvas{width:100%;height:150px;border-radius:var(--radius-sm)}.chart-loading,.chart-empty{font-size:.8rem;color:var(--text-muted);text-align:center;padding:16px 0}.scan-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.scan-camera{position:relative;border-radius:var(--radius);overflow:hidden;background:var(--bg-secondary);aspect-ratio:4/3}.scan-camera video{width:100%;height:100%;object-fit:cover}.scan-start{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:16px;padding:20px;text-align:center;color:var(--text-secondary)}.scan-controls{position:absolute;bottom:0;left:0;right:0;padding:16px;text-align:center}.scan-guide{position:absolute;bottom:60px;left:50%;transform:translate(-50%);text-align:center}.scan-guide-box{width:200px;height:50px;border:2px solid var(--accent);border-radius:8px;margin:0 auto 8px;box-shadow:0 0 20px var(--accent-glow)}.scan-guide span{font-size:.75rem;color:var(--accent)}.btn-capture{padding:14px 32px;border:none;border-radius:30px;background:var(--accent);color:#fff;font-weight:600;font-size:1rem;cursor:pointer}.btn-capture:disabled{opacity:.6}.scan-error{color:var(--danger);margin-top:12px;font-size:.9rem}.scan-result{margin-top:16px;padding:12px;background:var(--bg-secondary);border-radius:var(--radius-sm)}.scan-alternatives{color:var(--text-muted);font-size:.8rem;margin-top:4px}.scan-matches{margin-top:16px}.scan-matches h3{margin-bottom:10px}.scan-tip{color:var(--text-muted);font-size:.85rem;margin-top:12px;text-align:center}.stats-page h2{margin-bottom:16px}.stats-page h3{margin:20px 0 12px}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.stat-card{background:var(--bg-secondary);border-radius:var(--radius);padding:16px;text-align:center}.stat-card.highlight{background:linear-gradient(135deg,#e53e3e33,#ecc94b33)}.stat-value{display:block;font-size:1.5rem;font-weight:700}.stat-label{font-size:.8rem;color:var(--text-secondary)}.top-cards-list{display:flex;flex-direction:column;gap:8px}.top-card-item{display:flex;align-items:center;gap:10px;background:var(--bg-secondary);padding:10px;border-radius:var(--radius-sm)}.top-card-rank{font-weight:700;color:var(--warning);min-width:28px}.top-card-item img{width:40px;height:56px;object-fit:cover;border-radius:4px}.top-card-info{flex:1}.top-card-info strong{display:block;font-size:.9rem}.top-card-info span{font-size:.75rem;color:var(--text-secondary)}.top-card-price{color:var(--success);font-weight:700}.settings-page h2{margin-bottom:20px}.settings-section{background:var(--bg-secondary);border-radius:var(--radius);padding:16px;margin-bottom:12px}.settings-section h3{font-size:1rem;margin-bottom:8px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.settings-info p{margin-bottom:4px}.settings-role{color:var(--text-muted);font-size:.85rem}.add-child-form{display:flex;flex-direction:column;gap:10px}.add-child-form input{padding:10px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-primary);color:var(--text-primary);outline:none}.form-hint{font-size:.8rem;color:var(--text-muted)}.settings-profile-pic{width:80px;height:80px;border-radius:50%;overflow:hidden;cursor:pointer;margin:0 auto}.settings-profile-pic img{width:80px;height:80px;object-fit:cover;border-radius:50%}.settings-profile-placeholder{width:80px;height:80px;border-radius:50%;background:var(--bg-card);display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.settings-edit-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--bg-card)}.settings-edit-row .settings-label{display:block;font-size:.75rem;color:var(--text-muted);margin-bottom:2px}.settings-edit-inline{display:flex;gap:8px;align-items:center;padding:8px 0}.settings-edit-inline input{flex:1;padding:8px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-primary);color:var(--text-primary);outline:none}.settings-change-password{display:flex;flex-direction:column;gap:10px}.settings-change-password input{padding:10px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-primary);color:var(--text-primary);outline:none}.children-list{display:flex;flex-direction:column;gap:8px}.child-item{display:flex;justify-content:space-between;align-items:center;padding:10px;background:var(--bg-card);border-radius:var(--radius-sm)}.empty-state,.empty-hint{color:var(--text-muted);text-align:center;padding:32px 16px}.kids-binders-section{margin-top:24px}.kids-binders-title{font-size:1rem;color:var(--text-secondary);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--bg-card)}.admin-page h2{margin-bottom:16px}.admin-tabs{display:flex;gap:0;margin-bottom:16px;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border)}.admin-tabs button{flex:1;padding:10px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;font-weight:600;transition:all .2s}.admin-tabs button.active{background:var(--accent);color:#fff}.admin-success{background:#38a16933;color:var(--success);padding:10px 16px;border-radius:var(--radius-sm);margin-bottom:12px;font-size:.9rem}.admin-family-group{margin-bottom:4px}.admin-user-card{display:flex;justify-content:space-between;align-items:center;background:var(--bg-secondary);padding:12px 16px;border-radius:var(--radius-sm);margin-bottom:4px}.admin-user-parent{cursor:pointer;border-left:3px solid #63b3ed}.admin-user-child{margin-left:24px;background:var(--bg-card);border-left:3px solid #ecc94b;font-size:.9rem}.admin-user-name-row{display:flex;align-items:center;gap:8px}.family-count{font-size:.7rem;color:var(--text-muted);background:#ffffff14;padding:1px 8px;border-radius:10px}.expand-arrow{font-size:.7rem;color:var(--text-muted);transition:transform .2s}.expand-arrow.open{transform:rotate(180deg)}.admin-user-info{display:flex;flex-direction:column;gap:2px}.admin-user-info strong{font-size:.95rem}.admin-user-email{font-size:.8rem;color:var(--text-muted)}.admin-user-meta{font-size:.8rem;color:var(--text-secondary)}.admin-user-actions{display:flex;gap:8px}.role-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:.7rem;font-weight:600;text-transform:uppercase}.role-parent{background:#4299e133;color:#63b3ed}.role-child{background:#ecc94b33;color:#ecc94b}.role-super_admin{background:#e53e3e33;color:#fc8181}.admin-binder-card{background:var(--bg-secondary);border-radius:var(--radius-sm);margin-bottom:8px;overflow:hidden}.admin-binder-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;cursor:pointer;gap:12px}.admin-binder-row:hover{background:var(--bg-card)}.admin-binder-owner{font-size:.8rem;color:var(--text-muted);margin-left:8px}.admin-binder-meta{font-size:.8rem;color:var(--text-secondary);white-space:nowrap}.admin-binder-cards{padding:0 16px 12px}.admin-card-item{display:flex;align-items:center;gap:10px;padding:8px;background:var(--bg-card);border-radius:var(--radius-sm);margin-bottom:6px}.admin-card-item img{width:36px;height:50px;object-fit:cover;border-radius:3px}.admin-card-info{flex:1}.admin-card-info strong{display:block;font-size:.85rem}.admin-card-info span{font-size:.75rem;color:var(--text-secondary)}.admin-card-price{color:var(--success);font-size:.8rem;font-weight:600}.admin-edit-modal{background:var(--bg-secondary);border-radius:var(--radius);padding:24px;width:90%;max-width:400px;margin:auto}.admin-edit-modal h3{margin-bottom:16px}.admin-edit-form{display:flex;flex-direction:column;gap:12px}.admin-edit-form label{display:flex;flex-direction:column;gap:4px;font-size:.85rem;color:var(--text-secondary)}.admin-edit-form input{padding:10px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-primary);color:var(--text-primary);outline:none}.admin-edit-form input:focus{border-color:var(--accent)}.admin-edit-actions{display:flex;gap:10px;margin-top:4px}.toast-container{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:10000;display:flex;flex-direction:column-reverse;gap:8px;pointer-events:none;max-width:90vw;width:380px}.toast{pointer-events:auto;cursor:pointer;background:var(--bg-secondary);color:var(--text-primary);padding:12px 16px;border-radius:var(--radius-sm);border-left:4px solid var(--accent);box-shadow:0 4px 16px #0006;animation:toastSlideUp .3s ease;font-size:.9rem;line-height:1.4;word-break:break-word}.toast-success{border-left-color:var(--success)}.toast-error{border-left-color:var(--danger)}.toast-info{border-left-color:#3b82f6}@keyframes toastSlideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.collection-total-bar{display:flex;justify-content:center;align-items:center;gap:16px;background:var(--bg-secondary);border-radius:var(--radius-sm);padding:10px 16px;margin-bottom:16px;border:1px solid var(--border)}.collection-total-item{text-align:center}.collection-total-label{display:block;font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.collection-total-value{display:block;font-size:1.1rem;font-weight:700;color:var(--text-primary)}.collection-total-divider{width:1px;height:28px;background:var(--border)}.collection-total-price{color:var(--success)}.stats-breakdown{margin-bottom:20px}.stats-person-row{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;font-size:.85rem;color:var(--text-primary);border-bottom:1px solid var(--border)}.stats-person-row:last-child{border-bottom:none}.stats-person-name{font-weight:500}.stats-person-values{font-weight:600;white-space:nowrap}.stats-person-sep{color:var(--text-muted);margin:0 4px}.stats-person-divider{height:1px;background:var(--border);margin:0}.stats-person-total{font-weight:700;background:var(--bg-secondary);border-radius:var(--radius-sm)}.stats-person-total .stats-person-values{font-size:.9rem}.collection-search{margin-bottom:16px;position:relative}.collection-search-input{display:flex;align-items:center;gap:8px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px}.collection-search-input svg{width:18px;height:18px;color:var(--text-muted);flex-shrink:0}.collection-search-input input{flex:1;background:none;border:none;color:var(--text-primary);font-size:.9rem;outline:none}.collection-search-input input::placeholder{color:var(--text-muted)}.search-clear{background:none;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;padding:0 4px;line-height:1}.search-clear:hover{color:var(--text-primary)}.search-loading{font-size:.8rem;color:var(--text-muted);padding:8px 0}.collection-search-results{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);margin-top:4px;max-height:360px;overflow-y:auto}.search-no-results{padding:16px;text-align:center;color:var(--text-muted);font-size:.85rem}.search-result-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background:var(--bg-secondary)}.search-result-item img{width:36px;height:50px;object-fit:contain;border-radius:3px;flex-shrink:0}.search-result-info{flex:1;min-width:0}.search-result-info strong{display:block;font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-result-info span{display:block;font-size:.75rem;color:var(--text-muted)}.search-result-location{font-size:.7rem!important;color:var(--accent)!important}.search-result-price{font-weight:600;font-size:.85rem;color:var(--success);white-space:nowrap}.forgot-password-link{background:none;border:none;color:var(--text-muted);font-size:.85rem;cursor:pointer;margin-top:8px;text-decoration:underline;padding:0;transition:color .2s}.forgot-password-link:hover{color:var(--accent)}.forgot-password-form{display:flex;flex-direction:column;gap:12px;margin-top:12px;padding:16px;background:var(--bg-card);border-radius:var(--radius-sm);border:1px solid var(--border);animation:slideDown .2s ease}.forgot-password-form input{padding:12px 16px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-primary);color:var(--text-primary);outline:none}.forgot-password-form input:focus{border-color:var(--accent)}.forgot-hint{font-size:.8rem;color:var(--text-secondary);text-align:left}.forgot-success{color:var(--success);font-size:.85rem}.refresh-progress-label{display:inline-flex;align-items:center;gap:8px}.refresh-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:refreshSpin .8s linear infinite}@keyframes refreshSpin{to{transform:rotate(360deg)}}@media(max-width:400px){.card-detail-modal{flex-direction:column}.card-detail-modal>img{width:100%;border-radius:var(--radius) var(--radius) 0 0}}@media(min-width:768px){.binders-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.app-main{padding:24px}}
