.layout{display:flex;flex-direction:column;min-height:100vh}.header{background:var(--color-bg-card);border-bottom:1px solid var(--color-border);padding:var(--spacing-md) 0;position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.header-container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-lg);display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-xl)}.logo{display:flex;align-items:center;gap:var(--spacing-sm);text-decoration:none}.logo-text{font-family:var(--font-display);font-size:1.5rem;font-weight:600;color:var(--color-accent-primary)}.logo-lens{font-size:1.2rem;margin:0 -2px}.nav{display:flex;gap:var(--spacing-lg)}.nav-link{padding:var(--spacing-sm) var(--spacing-md);color:var(--color-text-secondary);font-weight:500;text-decoration:none;border-radius:var(--radius-md);transition:all var(--transition-fast)}.nav-link:hover{color:var(--color-text-primary);background:#3d2b1f0d}.nav-link.active{color:var(--color-accent-primary);background:#3d2b1f1a}.header-right{display:flex;align-items:center;gap:var(--spacing-md)}.profile-link{display:flex;align-items:center;gap:var(--spacing-sm);text-decoration:none;color:var(--color-text-secondary);transition:color var(--transition-fast)}.profile-link:hover{color:var(--color-text-primary)}.profile-avatar{width:36px;height:36px;border-radius:50%;background:var(--color-accent-gradient);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem}.profile-name{font-size:.875rem}.btn-logout{padding:var(--spacing-sm) var(--spacing-md);background:transparent;color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.875rem;cursor:pointer;transition:all var(--transition-fast)}.btn-logout:hover{color:var(--color-text-primary);border-color:var(--color-text-secondary)}.access-banner{padding:var(--spacing-sm) var(--spacing-md);text-align:center;font-size:.875rem;font-weight:500}.access-banner.paid{background:linear-gradient(90deg,#4a7c5926,#4a7c591a);color:var(--color-success)}.access-banner.free{background:#5a7c9c1a;color:var(--color-info)}.main-content{flex:1;padding:var(--spacing-xl) 0}.footer{background:var(--color-bg-secondary);border-top:1px solid var(--color-border);padding:var(--spacing-xl) 0;margin-top:auto}.footer-container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-lg);text-align:center}.footer-text{color:var(--color-text-secondary);font-size:.875rem;margin-bottom:var(--spacing-sm)}.footer-disclaimer{color:var(--color-text-muted);font-size:.75rem;max-width:600px;margin:0 auto}@media (max-width: 768px){.header-container{flex-wrap:wrap;gap:var(--spacing-md)}.nav{order:3;width:100%;justify-content:center}.profile-name{display:none}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.auth-background{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0}.auth-bg-pattern{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 20% 80%,rgba(61,43,31,.08) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(61,43,31,.06) 0%,transparent 50%),radial-gradient(circle at 50% 50%,rgba(245,242,237,.9) 0%,var(--color-bg-primary) 100%)}.auth-bg-pattern:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%233D2B1F' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");opacity:.5}.auth-container{position:relative;z-index:1;width:100%;max-width:440px;padding:var(--spacing-lg)}.auth-card{padding:var(--spacing-2xl)}.auth-logo{text-align:center;margin-bottom:var(--spacing-xl)}.auth-logo-icon{font-size:3rem;display:block;margin-bottom:var(--spacing-sm)}.auth-logo-text{font-family:var(--font-display);font-size:2rem;color:var(--color-accent-primary);margin-bottom:var(--spacing-xs)}.auth-logo-tagline{color:var(--color-text-secondary);font-size:.875rem;margin:0}.auth-form{margin-bottom:var(--spacing-lg)}.auth-error{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);color:var(--color-error);font-size:.875rem;margin-bottom:var(--spacing-lg)}.auth-error-icon{flex-shrink:0}.input-wrapper{position:relative}.input-icon{position:absolute;left:var(--spacing-md);top:50%;transform:translateY(-50%);font-size:1rem;opacity:.5}.form-input.with-icon{padding-left:2.75rem}.password-toggle{position:absolute;right:var(--spacing-md);top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:1rem;opacity:.5;transition:opacity var(--transition-fast)}.password-toggle:hover{opacity:1}.form-actions{display:flex;justify-content:flex-end;margin-bottom:var(--spacing-lg)}.forgot-link{font-size:.875rem;color:var(--color-accent-primary)}.auth-submit{width:100%;padding:var(--spacing-md) var(--spacing-xl);font-size:1rem}.checkbox-group{margin-bottom:var(--spacing-lg)}.checkbox-label{display:flex;align-items:flex-start;gap:var(--spacing-sm);cursor:pointer}.checkbox-input{position:absolute;opacity:0;width:0;height:0}.checkbox-custom{flex-shrink:0;width:20px;height:20px;border:2px solid var(--color-border-accent);border-radius:var(--radius-sm);background:transparent;position:relative;transition:all var(--transition-fast)}.checkbox-input:checked+.checkbox-custom{background:var(--color-accent-primary);border-color:var(--color-accent-primary)}.checkbox-input:checked+.checkbox-custom:after{content:"✓";position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.75rem;font-weight:700}.checkbox-text{font-size:.875rem;color:var(--color-text-secondary);line-height:1.4}.inline-link{background:none;border:none;color:var(--color-accent-primary);cursor:pointer;text-decoration:underline;font-size:inherit;padding:0}.auth-footer{text-align:center}.auth-footer p{color:var(--color-text-secondary);font-size:.875rem;margin:0}.auth-link{color:var(--color-accent-primary);font-weight:500}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-lg);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{position:relative;max-width:480px;width:100%;max-height:90vh;overflow-y:auto;padding:var(--spacing-xl);animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-close{position:absolute;top:var(--spacing-md);right:var(--spacing-md);background:none;border:none;color:var(--color-text-muted);cursor:pointer;font-size:1.25rem;padding:var(--spacing-sm);transition:color var(--transition-fast)}.modal-close:hover{color:var(--color-text-primary)}.modal-title{font-size:1.5rem;margin-bottom:var(--spacing-lg)}.modal-body{margin-bottom:var(--spacing-xl)}.modal-body p{margin-bottom:var(--spacing-md)}.policy-list{list-style:none;padding:0;margin:var(--spacing-md) 0}.policy-list li{position:relative;padding-left:var(--spacing-lg);margin-bottom:var(--spacing-md);color:var(--color-text-secondary);font-size:.875rem;line-height:1.6}.policy-list li:before{content:"•";position:absolute;left:0;color:var(--color-accent-primary)}.policy-note{font-size:.875rem;color:var(--color-text-muted);font-style:italic}.modal-accept{width:100%}@media (max-width: 480px){.auth-card{padding:var(--spacing-xl)}.auth-logo-text{font-size:1.75rem}}.identify-page{padding:var(--spacing-lg) 0}.page-header{text-align:center;margin-bottom:var(--spacing-2xl)}.page-header p{max-width:600px;margin:0 auto}.identify-form{max-width:800px;margin:0 auto}.form-error{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);color:var(--color-error);margin-bottom:var(--spacing-lg)}.error-icon{flex-shrink:0}.form-section{margin-bottom:var(--spacing-xl)}.section-label{display:flex;align-items:baseline;gap:var(--spacing-md);font-size:1rem;font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-md)}.label-hint{font-size:.875rem;font-weight:400;color:var(--color-text-muted)}.drop-zone{position:relative;padding:var(--spacing-2xl);border:2px dashed var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-card);text-align:center;cursor:pointer;transition:all var(--transition-normal)}.drop-zone:hover,.drop-zone.dragging{border-color:var(--color-accent-primary);background:#d4a8530d}.drop-zone-content{pointer-events:none}.drop-icon{font-size:3rem;display:block;margin-bottom:var(--spacing-md)}.drop-text{color:var(--color-text-primary);font-size:1rem;margin-bottom:var(--spacing-sm)}.drop-hint{color:var(--color-text-muted);font-size:.875rem;margin:0}.file-input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.mobile-capture-options{display:none}@media (max-width: 768px){.drop-zone{display:none}.mobile-capture-options{display:flex;flex-direction:column;gap:var(--spacing-md)}.capture-btn{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);padding:24px;font-size:1.1rem;font-weight:600;border:2px dashed var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-card);cursor:pointer;transition:all var(--transition-fast);width:100%}.capture-btn:active{transform:scale(.98)}.capture-btn.camera{border-color:var(--color-accent-primary);background:#d4a8531a;color:var(--color-accent-primary)}.capture-btn.gallery{color:var(--color-text-secondary)}.btn-icon{font-size:1.5rem}}.image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--spacing-md)}.image-card{position:relative;aspect-ratio:1;border-radius:var(--radius-md);overflow:hidden;background:var(--color-bg-secondary);border:2px solid var(--color-border);transition:border-color var(--transition-fast)}.image-card.main-view{border-color:var(--color-accent-primary)}.upload-progress-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:5}.progress-bar-fill{height:4px;background:var(--color-accent-primary);position:absolute;bottom:0;left:0;transition:width .3s ease}.progress-text{font-size:.875rem;font-weight:700;color:var(--color-accent-primary)}.image-preview{width:100%;height:100%;object-fit:cover}.main-badge{position:absolute;bottom:var(--spacing-sm);left:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-accent-primary);color:var(--color-bg-primary);font-size:.75rem;font-weight:600;border-radius:var(--radius-sm)}.resized-badge{position:absolute;top:var(--spacing-sm);left:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);background:#0009;color:var(--color-text-secondary);font-size:.625rem;font-weight:500;border-radius:var(--radius-sm)}.image-actions{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);display:flex;gap:var(--spacing-xs)}.image-btn{padding:var(--spacing-xs) var(--spacing-sm);background:#000000b3;border:none;border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:.75rem;cursor:pointer;transition:background var(--transition-fast)}.image-btn:hover{background:#000000e6}.image-btn.remove{padding:var(--spacing-xs);color:var(--color-error)}.image-btn.set-main{color:var(--color-accent-primary)}.form-actions{text-align:center;padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.submit-btn{min-width:200px;display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.submit-btn:disabled{opacity:.5;cursor:not-allowed}.submit-note{margin-top:var(--spacing-md);font-size:.75rem;color:var(--color-text-muted)}@media (max-width: 640px){.category-grid,.image-grid{grid-template-columns:repeat(2,1fr)}}.results-page{padding:var(--spacing-lg) 0}.results-page.loading,.results-page.error{min-height:calc(100vh - 200px);display:flex;align-items:center;justify-content:center}.loading-content,.error-content{text-align:center}.loading-spinner.large{width:64px;height:64px;margin:0 auto var(--spacing-lg)}.error-content h2{color:var(--color-accent-primary);margin-bottom:var(--spacing-md)}.results-header{margin-bottom:var(--spacing-xl)}.back-link{display:inline-block;color:var(--color-text-secondary);margin-bottom:var(--spacing-md);font-size:.875rem}.back-link:hover{color:var(--color-accent-primary)}.results-header h1{color:var(--color-text-primary);font-size:2rem}.result-card{padding:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.result-main{display:grid;grid-template-columns:300px 1fr;gap:var(--spacing-xl)}.result-image{aspect-ratio:1;border-radius:var(--radius-lg);overflow:hidden;background:var(--color-bg-secondary)}.result-image img{width:100%;height:100%;object-fit:cover}.result-details{display:flex;flex-direction:column;gap:var(--spacing-md)}.detail-row{display:flex;gap:var(--spacing-md)}.detail-label{color:var(--color-text-muted);min-width:120px}.detail-value{color:var(--color-text-primary);font-weight:500}.detail-value.highlight{color:var(--color-accent-primary);font-size:1.25rem}.confidence-section{display:flex;align-items:center;gap:var(--spacing-md);margin:var(--spacing-md) 0}.confidence-gauge{position:relative;width:80px;height:80px}.gauge-svg{transform:rotate(-90deg)}.gauge-bg{fill:none;stroke:var(--color-border);stroke-width:8}.gauge-fill{fill:none;stroke-width:8;stroke-linecap:round;transition:stroke-dasharray 1s ease}.confidence-gauge.high .gauge-fill{stroke:var(--color-success)}.confidence-gauge.medium .gauge-fill{stroke:var(--color-warning)}.confidence-gauge.low .gauge-fill{stroke:var(--color-error)}.gauge-value{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:700;color:var(--color-accent-primary)}.confidence-label{color:var(--color-text-muted);font-size:.875rem}.price-section{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}.price-label{display:block;color:var(--color-text-muted);font-size:.875rem;margin-bottom:var(--spacing-xs)}.price-value{font-size:1.5rem;font-weight:700;color:var(--color-accent-primary)}.supporting-details{margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.details-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--spacing-md);background:#3d2b1f14;border:none;border-radius:var(--radius-md);color:var(--color-accent-primary);font-weight:600;cursor:pointer;transition:background var(--transition-fast)}.details-toggle:hover{background:#3d2b1f1f}.toggle-icon{transition:transform var(--transition-fast)}.toggle-icon.open{transform:rotate(180deg)}.details-content{padding:var(--spacing-lg);display:grid;gap:var(--spacing-md)}.detail-item{color:var(--color-text-secondary);font-size:.875rem;line-height:1.6}.detail-item strong{color:var(--color-text-primary)}.similar-section{margin-bottom:var(--spacing-xl)}.similar-section h2{font-size:1.25rem;margin-bottom:var(--spacing-lg)}.similar-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-md)}.similar-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;transition:border-color var(--transition-fast)}.similar-card:hover{border-color:var(--color-accent-primary)}.similar-image{aspect-ratio:1;background:var(--color-bg-secondary)}.similar-image img{width:100%;height:100%;object-fit:cover}.similar-info{padding:var(--spacing-md)}.similar-info h4{font-size:.875rem;margin-bottom:var(--spacing-xs)}.similar-info p{font-size:.75rem;color:var(--color-text-muted);margin-bottom:var(--spacing-sm)}.similar-price{font-size:.875rem;font-weight:600;color:var(--color-accent-primary)}.disclaimer{padding:var(--spacing-md);background:#3b82f61a;border:1px solid rgba(59,130,246,.2);border-radius:var(--radius-md);margin-bottom:var(--spacing-xl)}.disclaimer p{font-size:.75rem;color:var(--color-text-muted);margin:0;line-height:1.6}.result-actions{display:flex;gap:var(--spacing-md);justify-content:center}@media (max-width: 768px){.result-main{grid-template-columns:1fr}.result-image{max-width:300px;margin:0 auto}.result-actions,.hallmark-images-row{flex-direction:column}.hallmark-image-wrapper{min-width:100%;aspect-ratio:4/3}.approval-actions{flex-direction:column;gap:var(--spacing-md)}.approval-actions .btn-large{width:100%}.hallmark-grid{grid-template-columns:1fr}}.hallmark-section{padding:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.hallmark-section h2{margin-bottom:var(--spacing-sm)}.section-description{color:var(--color-text-muted);margin-bottom:var(--spacing-lg)}.hallmark-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-lg)}.hallmark-card{background:var(--color-bg-secondary);border:2px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:border-color var(--transition-fast)}.hallmark-card:hover{border-color:var(--color-accent-primary)}.hallmark-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.manufacturer-name{font-size:1.1rem;color:var(--color-accent-primary)}.match-score{background:linear-gradient(135deg,var(--color-accent-primary),var(--color-accent-light));color:#fff;padding:4px 12px;border-radius:var(--radius-full);font-size:.75rem;font-weight:700}.match-badges{display:flex;gap:8px;align-items:center}.verified-badge{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;padding:4px 10px;border-radius:var(--radius-full);font-size:.7rem;font-weight:700}.verified-hint{display:block;color:#22c55e;font-size:.8rem;margin-top:8px}.hallmark-card.verified{border-color:#22c55e;background:#22c55e0d}.hallmark-images-row{display:flex;gap:12px;margin:16px 0;overflow-x:auto}.hallmark-image-wrapper{flex:1;position:relative!important;border-radius:8px;overflow:hidden;background:var(--color-bg-hallmark);aspect-ratio:1;display:flex;align-items:center;justify-content:center;min-width:120px}.hallmark-image-wrapper img{width:100%;height:100%;object-fit:contain}.image-label{position:absolute;bottom:0;left:0;right:0;background:#0009;color:#ffffffe6;font-size:.7rem;padding:2px 4px;text-align:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.image-fallback-text{position:absolute;font-size:2rem;font-weight:700;color:#ccc;z-index:1}.card-actions{display:flex;gap:8px;margin-top:10px}.hallmark-details{margin-bottom:var(--spacing-md)}.hallmark-details .description{color:var(--color-text-primary);margin-bottom:var(--spacing-xs);font-size:.875rem}.hallmark-details .period,.hallmark-details .source{font-size:.75rem;color:var(--color-text-muted);margin-bottom:var(--spacing-xs)}.btn-outline{background:transparent;border:1px solid var(--color-accent-primary);color:var(--color-accent-primary)}.btn-outline:hover{background:var(--color-accent-primary);color:#fff}.btn-small{padding:8px 16px;font-size:.75rem}.approval-section{padding:var(--spacing-xl);margin-bottom:var(--spacing-xl);border:2px solid var(--color-accent-primary);text-align:center}.approval-section h2{color:var(--color-accent-primary);margin-bottom:var(--spacing-md)}.approval-instruction{color:var(--color-text-secondary);margin-bottom:var(--spacing-lg);max-width:600px;margin-left:auto;margin-right:auto}.approval-actions{display:flex;gap:var(--spacing-lg);justify-content:center;flex-wrap:wrap}.btn-large{padding:16px 32px;font-size:1rem;font-weight:600}.btn-success{background:linear-gradient(135deg,#22c55e,#16a34a);border:none;color:#fff}.btn-success:hover{background:linear-gradient(135deg,#16a34a,#15803d)}.btn-success:disabled{background:#4b5563;cursor:not-allowed}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);border:none;color:#fff}.btn-danger:hover{background:linear-gradient(135deg,#dc2626,#b91c1c)}.btn-danger:disabled{background:#4b5563;cursor:not-allowed}.status-banner{padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);text-align:center;font-weight:600;margin-bottom:var(--spacing-xl)}.status-banner.approved{background:#22c55e26;border:1px solid rgba(34,197,94,.3);color:#22c55e}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-lg)}.info-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.info-card h3{color:var(--color-accent-primary);margin-bottom:var(--spacing-md);font-size:1rem}.price-card .price-value{font-size:1.5rem;font-weight:700;color:var(--color-accent-primary)}.price-card .price-avg{color:var(--color-text-muted);font-size:.875rem;margin:var(--spacing-sm) 0}.source-badge{display:inline-block;background:#3d2b1f1a;color:var(--color-accent-primary);padding:4px 8px;border-radius:var(--radius-sm);font-size:.75rem}.catalog-list{list-style:none;padding:0;margin:0}.catalog-list li{display:flex;flex-direction:column;gap:4px;padding:var(--spacing-sm) 0;border-bottom:1px solid var(--color-border)}.catalog-list li:last-child{border-bottom:none}.catalog-list a{color:var(--color-text-primary);text-decoration:none}.catalog-list a:hover{color:var(--color-accent-primary)}.catalog-source{font-size:.75rem;color:var(--color-text-muted)}.view-link{display:inline-block;margin-top:var(--spacing-sm);color:var(--color-accent-primary);font-size:.75rem}.no-matches{color:var(--color-text-muted);text-align:center;padding:var(--spacing-lg)}.history-page{padding:var(--spacing-lg) 0}.history-page.loading{min-height:calc(100vh - 200px);display:flex;flex-direction:column;align-items:center;justify-content:center}.page-header{margin-bottom:var(--spacing-xl)}.page-header h1{color:var(--color-accent-primary);margin-bottom:var(--spacing-sm)}.filters-bar{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-xl);padding:var(--spacing-md);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);flex-wrap:wrap;align-items:flex-end}.filter-group{flex:1;min-width:150px}.filter-label{display:block;font-size:.75rem;color:var(--color-text-muted);margin-bottom:var(--spacing-xs)}.filter-select{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:.875rem;cursor:pointer}.filter-select:focus{outline:none;border-color:var(--color-accent-primary)}.filter-btn{padding:var(--spacing-sm) var(--spacing-lg)}.empty-state{text-align:center;padding:var(--spacing-2xl)}.empty-icon{font-size:4rem;margin-bottom:var(--spacing-lg)}.empty-state h2{color:var(--color-accent-primary);margin-bottom:var(--spacing-sm)}.empty-state p{margin-bottom:var(--spacing-xl)}.history-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.history-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-normal)}.history-card:hover{border-color:var(--color-accent-primary);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.card-image{display:block;aspect-ratio:1;background:var(--color-bg-secondary)}.card-image img{width:100%;height:100%;object-fit:cover}.card-content{padding:var(--spacing-md)}.card-title{font-size:1rem;font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-sm);line-height:1.4}.card-title:hover{color:var(--color-accent-primary)}.card-date{font-size:.75rem;color:var(--color-text-muted);margin-bottom:var(--spacing-sm)}.card-meta{margin-bottom:var(--spacing-sm)}.confidence-badge{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-full);font-size:.75rem;font-weight:600}.confidence-badge.high{background:#10b98133;color:var(--color-success);border:1px solid rgba(16,185,129,.3)}.confidence-badge.medium{background:#f59e0b33;color:var(--color-warning);border:1px solid rgba(245,158,11,.3)}.confidence-badge.low{background:#ef444433;color:var(--color-error);border:1px solid rgba(239,68,68,.3)}.card-price{font-size:.875rem;color:var(--color-text-secondary);margin-bottom:var(--spacing-md)}.card-price span{color:var(--color-accent-primary);font-weight:600}.card-actions{display:flex;gap:var(--spacing-sm)}.action-btn{flex:1;padding:var(--spacing-sm);font-size:.75rem;font-weight:500;border:none;border-radius:var(--radius-md);cursor:pointer;text-align:center;text-decoration:none;transition:all var(--transition-fast)}.action-btn.view{background:#d4a8531a;color:var(--color-accent-primary)}.action-btn.view:hover{background:#d4a85333}.action-btn.delete{background:transparent;color:var(--color-text-muted)}.action-btn.delete:hover{background:#ef44441a;color:var(--color-error)}.pagination{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md)}.page-btn{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:.875rem;cursor:pointer;transition:all var(--transition-fast)}.page-btn:hover:not(:disabled){border-color:var(--color-accent-primary);color:var(--color-accent-primary)}.page-btn:disabled{opacity:.5;cursor:not-allowed}.page-info{color:var(--color-text-muted);font-size:.875rem}.btn-danger{background:var(--color-error);color:#fff}.btn-danger:hover{background:#dc2626}.modal-actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-xl)}.modal-actions .btn{flex:1}@media (max-width: 640px){.filters-bar{flex-direction:column}.filter-group{width:100%}.history-grid{grid-template-columns:1fr}.card-actions{flex-direction:column}}.admin-quick-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-bottom:2rem}.admin-action-card{text-decoration:none;color:inherit;transition:transform .2s,background-color .2s;border:1px solid rgba(255,255,255,.1)}.admin-action-card:hover{transform:translateY(-4px);background:#ffffff0d;border-color:#fff3}.admin-action-card .card-content{display:flex;align-items:center;gap:1.5rem;padding:1.5rem}.admin-action-card .card-icon{font-size:2rem;background:#ffffff0d;width:60px;height:60px;display:flex;align-items:center;justify-content:center;border-radius:12px}.admin-action-card .card-text h3{margin:0;font-size:1.2rem;color:#fff}.admin-action-card .card-text p{margin:.3rem 0 0;font-size:.9rem;color:#888}.clickable{cursor:pointer}.admin-page{padding-top:100px;padding-bottom:60px}.admin-page .page-header .header-content h1{margin:0}.admin-page .page-header .header-content p{margin:5px 0 0;color:var(--text-muted)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:40px}.stat-card{display:flex;align-items:center;padding:25px;gap:20px;transition:transform .3s ease;container-type:inline-size}.stat-card:hover{transform:translateY(-5px)}.stat-icon{font-size:2.5rem;color:var(--accent-primary)}.stat-info h3{font-size:clamp(.6rem,6cqi,.8rem);color:var(--text-muted);margin:0 0 5px;text-transform:uppercase;letter-spacing:.5px;white-space:normal;line-height:1.25;word-wrap:break-word;width:100%}.stat-value{font-size:2rem;font-weight:700;color:var(--white);line-height:1}.admin-content-grid.single-column{display:flex;justify-content:center;margin-top:2rem}.system-status-section{max-width:600px;width:100%}.admin-section{padding:30px}.admin-section h2{margin-top:0;margin-bottom:25px;font-size:1.5rem;color:var(--accent-primary)}:root{--porcelain-bg: #FDFBF7;--porcelain-text: #3E2723;--porcelain-border: #8D6E63;--porcelain-accent: #D7CCC8}.admin-page{padding-top:100px;padding-bottom:60px;color:var(--porcelain-text)}.admin-page .page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.admin-page .page-header .header-content h1{margin:0;color:var(--porcelain-text);font-size:2.2rem}.admin-page .page-header .header-content p{margin:5px 0 0;color:var(--porcelain-border)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:40px}.stat-card{display:flex;align-items:center;padding:25px;gap:20px;transition:all .2s ease;background:#fff;border:1px solid var(--porcelain-border);border-radius:8px;box-shadow:0 4px 6px -1px #3e27231a;text-decoration:none;color:inherit}.stat-card:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #3e272326;border-color:var(--porcelain-text)}.stat-icon{font-size:2.5rem;color:var(--porcelain-border)}.stat-info h3{font-size:.9rem;color:var(--porcelain-border);margin:0 0 5px;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.stat-value{font-size:2rem;font-weight:700;color:var(--porcelain-text);line-height:1}.stat-subtext{font-size:.8rem;color:#8d6e63;margin-top:4px;display:block}.admin-section h2{margin-top:0;margin-bottom:25px;font-size:1.5rem;color:var(--porcelain-text)}.health-item{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;background:#fff;border:1px solid rgba(141,110,99,.3);border-radius:6px;margin-bottom:10px;color:var(--porcelain-text)}.health-list{display:flex;flex-direction:column;gap:15px}.health-item{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;background:#ffffff0d;border-radius:8px}.health-label{font-weight:500}.health-status.status-ok{color:#4caf50;font-weight:700}.admin-denied{height:100vh;display:flex;align-items:center;justify-content:center;text-align:center}.admin-denied h1{color:var(--error-color);font-size:3rem;margin-bottom:20px}.billing-widget{position:relative;display:flex;align-items:center;gap:15px;padding:20px;transition:transform .2s ease,box-shadow .2s ease;min-height:100px}.billing-widget:hover{transform:translateY(-2px);box-shadow:0 8px 32px #1f268726}.billing-widget.loading{opacity:.8}.billing-widget.error{border:1px solid rgba(244,67,54,.3)}.status-pending{color:#ff9800;font-weight:500}.timestamp{font-size:.75rem;opacity:.7}.retry-text{font-size:.75rem;color:#2196f3;text-decoration:underline;margin-top:5px;display:block}.external-link-icon{position:absolute;top:10px;right:10px;font-size:.9rem;text-decoration:none;opacity:.5;transition:opacity .2s}.external-link-icon:hover{opacity:1}.billing-widget .stat-icon{font-size:2rem;background:#4caf501a;width:50px;height:50px;display:flex;align-items:center;justify-content:center;border-radius:12px}.billing-widget.error .stat-icon{background:#f443361a}.billing-widget .stat-info h3{margin:0;font-size:.9rem;color:#666;font-weight:500}.billing-widget .stat-value{font-size:1.5rem;font-weight:700;color:#333;margin:4px 0}.billing-widget .stat-subtext{font-size:.8rem;color:#888}.loading-spinner.small{width:20px;height:20px;border:2px solid rgba(0,0,0,.1);border-top:2px solid #2196f3;border-radius:50%;animation:spin 1s linear infinite;margin-top:5px}.billing-details{display:flex;flex-direction:column;gap:4px;margin-top:8px}.savings-row,.net-row{display:flex;justify-content:space-between;font-size:.85rem}.savings-label,.net-label{opacity:.8}.savings-value{color:#4caf50;font-weight:600}.net-value{font-weight:500}.timestamp-row{font-size:.7rem;opacity:.5;margin-top:4px;font-style:italic}.regression-dashboard{margin-top:2rem;width:100%}.regression-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.regression-header h2{margin:0}.run-test-btn{padding:10px 20px;background-color:var(--porcelain-border);color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px}.run-test-btn:hover:not(:disabled){background-color:var(--porcelain-text);transform:translateY(-1px)}.run-test-btn:disabled{opacity:.6;cursor:not-allowed}.metrics-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.metric-box{background:#fff;padding:20px;border-radius:8px;border:1px solid rgba(141,110,99,.2);box-shadow:0 2px 4px #0000000d}.metric-label{display:block;font-size:.85rem;color:var(--porcelain-border);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.metric-value-row{display:flex;align-items:baseline;gap:12px}.metric-value{font-size:2rem;font-weight:700;color:var(--porcelain-text)}.metric-delta{font-size:.9rem;font-weight:600}.delta-positive{color:#4caf50}.delta-negative{color:#f44336}.delta-neutral{color:#888}.regression-history{background:#fff;border-radius:8px;border:1px solid rgba(141,110,99,.2);overflow:hidden}.regression-history table{width:100%;border-collapse:collapse;font-size:.95rem}.regression-history th{text-align:left;padding:12px 15px;background:#f9f7f5;border-bottom:1px solid rgba(141,110,99,.1);color:var(--porcelain-border);font-weight:600}.regression-history td{padding:12px 15px;border-bottom:1px solid rgba(141,110,99,.05)}.regression-history tr:last-child td{border-bottom:none}.run-desc{font-size:.8rem;color:#666;display:block}.status-badge{padding:4px 8px;border-radius:4px;font-size:.75rem;font-weight:700;text-transform:uppercase}.status-baseline{background:#e3f2fd;color:#1976d2}.loading-overlay{background:#fffc;padding:40px;text-align:center;border-radius:8px;color:var(--porcelain-text)}:root{--porcelain-bg: #FDFBF7;--porcelain-text: #3E2723;--porcelain-border: #8D6E63;--porcelain-accent: #D7CCC8;--porcelain-input-bg: #FFFFFF;--porcelain-sidebar-bg: #EFEBE9}.admin-config-page{min-height:100vh;padding:2rem 0;color:var(--porcelain-text);font-family:Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.config-header{margin-bottom:2rem}.config-header h1{color:var(--porcelain-text);margin-bottom:.5rem}.config-header p{color:var(--porcelain-border)}.back-link{color:var(--porcelain-border);text-decoration:none;font-size:.9rem;margin-bottom:1rem;display:inline-block}.back-link:hover{color:var(--porcelain-text)}.config-layout{display:flex;gap:2rem;align-items:flex-start}.config-sidebar{width:250px;flex-shrink:0;background:var(--porcelain-sidebar-bg);border:1px solid var(--porcelain-border);border-radius:8px;overflow:hidden}.sidebar-nav{display:flex;flex-direction:column}.sidebar-nav button{text-align:left;padding:1rem 1.5rem;background:transparent;border:none;border-bottom:1px solid rgba(141,110,99,.2);color:var(--porcelain-text);cursor:pointer;font-weight:500;transition:all .2s}.sidebar-nav button:hover{background:#8d6e631a}.sidebar-nav button.active{background:var(--porcelain-border);color:#fff}.config-content{flex-grow:1;min-width:0}.config-content fieldset{border:2px solid var(--porcelain-border);border-radius:8px;padding:1.5rem;margin-bottom:2rem;background:var(--porcelain-input-bg)}.config-content legend{color:var(--porcelain-text);font-weight:700;padding:0 10px;font-size:1.1rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.config-content input,.config-content select,.config-content textarea{width:100%;padding:.8rem;background:var(--porcelain-input-bg);border:2px solid var(--porcelain-border);border-radius:6px;color:var(--porcelain-text);font-size:1rem;margin-bottom:1rem}.config-content input:focus,.config-content select:focus,.config-content textarea:focus{outline:none;box-shadow:0 0 0 3px #8d6e6333}.config-content label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--porcelain-text)}.source-card,.mark-card,.database-launch-card{background:var(--porcelain-input-bg);border:1px solid var(--porcelain-border);border-radius:8px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 2px 4px #3e27230d}.source-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.status-badge{padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:700;text-transform:uppercase}.status-badge.active{background:#e8f5e9;color:#2e7d32;border:1px solid #C8E6C9}.status-badge.inactive{background:#ffebee;color:#c62828;border:1px solid #FFCDD2}.btn{padding:.75rem 1.5rem;border-radius:6px;font-weight:600;cursor:pointer;border:none;transition:all .2s}.btn-primary{background:var(--porcelain-border);color:#fff}.btn-primary:hover{background:var(--porcelain-text)}.btn-secondary{background:transparent;border:2px solid var(--porcelain-border);color:var(--porcelain-text)}.btn-danger{background:#ff5252;color:#fff}.source-actions{display:flex;gap:.5rem;margin-top:1rem;flex-wrap:wrap}.btn-edit,.btn-toggle,.btn-delete,.btn-scrape-small,.btn-clear-data{padding:.5rem 1rem;border-radius:4px;font-size:.85rem;cursor:pointer;border:1px solid var(--porcelain-border);background:#fff;color:var(--porcelain-text)}.btn-edit:hover,.btn-toggle:hover,.btn-delete:hover{background:#efebe9}.scrape-progress{background:#efebe9;padding:1.5rem;border-radius:8px;margin-bottom:2rem;border:1px solid var(--porcelain-border)}.progress-bar-container{height:12px;background:#d7ccc8;border-radius:6px;overflow:hidden;margin-top:.5rem}.progress-bar{height:100%;background:var(--porcelain-border);transition:width .3s}.sources-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}@media (max-width: 768px){.config-layout{flex-direction:column}.config-sidebar{width:100%}}.mark-db-page{padding:2rem 0;min-height:100vh}.mark-db-page .page-header{margin-bottom:2rem}.mark-db-page .search-bar{display:flex;align-items:center;padding:.8rem 1.5rem;margin-bottom:2.5rem;border-radius:12px}.mark-db-page .search-bar input{background:transparent;border:none;color:#3e2723;width:100%;font-size:1.1rem;padding-left:1rem}.mark-db-page .search-bar input::placeholder{color:#8d6e63;opacity:.7}.mark-db-page .search-bar{display:flex;align-items:center;padding:.8rem 1.5rem;margin-bottom:2.5rem;border-radius:12px;background:#fff;border:2px solid #8D6E63;box-shadow:0 4px 6px -1px #3e27231a}.mark-db-page .search-bar input:focus{outline:none}.mark-db-page .marks-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:2rem;margin-bottom:3rem}.mark-db-page .mark-card{display:flex;flex-direction:column;height:100%;overflow:hidden;transition:transform .2s;border:1px solid rgba(255,255,255,.1)}.mark-db-page .mark-card:hover{transform:translateY(-5px)}.mark-db-page .mark-img{width:100%;height:200px;background:#0000004d;display:flex;align-items:center;justify-content:center;padding:1rem}.mark-db-page .mark-img img{max-width:100%;max-height:100%;object-fit:contain;border-radius:4px}.mark-db-page .mark-info{padding:1.25rem;flex-grow:1;display:flex;flex-direction:column}.mark-db-page .mark-info h3{margin:0 0 .5rem;font-size:1.2rem;color:var(--accent-primary)}.mark-db-page .mark-meta{font-size:.9rem;color:var(--text-secondary);margin-bottom:.75rem}.mark-db-page .mark-desc{font-size:.85rem;line-height:1.4;color:var(--text-muted);margin-bottom:1.25rem;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;flex-grow:1}.mark-db-page .mark-footer{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid rgba(255,255,255,.05)}.mark-db-page .mark-source{font-size:.75rem;color:var(--text-muted);font-style:italic}.mark-db-page .btn-delete{background:#ff44441a;border:1px solid rgba(255,68,68,.2);color:#f44;font-size:1rem;padding:.4rem;border-radius:6px;cursor:pointer;transition:all .2s}.mark-db-page .btn-delete:hover{background:#f44;color:#fff}.mark-db-page .load-more{display:flex;justify-content:center;padding:2rem 0}.mark-db-page .loader-small{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:var(--accent-primary);animation:spin 1s linear infinite}.mark-db-page .empty-state{text-align:center;padding:4rem 2rem;color:var(--text-secondary)}.user-management-container{padding:2rem;max-width:1200px;margin:0 auto;color:#e0e0e0}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.admin-header h1{margin:0;font-size:1.8rem;color:#fff}.back-btn{background:transparent;border:1px solid #444;color:#aaa;padding:.5rem 1rem;border-radius:4px;cursor:pointer;transition:all .2s}.back-btn:hover{border-color:#666;color:#fff}.search-bar input{background:#1e1e1e;border:1px solid #333;color:#fff;padding:.6rem 1.2rem;border-radius:20px;width:300px;outline:none}.search-bar input:focus{border-color:#0078d4;box-shadow:0 0 0 2px #0078d433}.users-table-container{background:#1a1a1a;border-radius:8px;border:1px solid #333;overflow:hidden}.users-table{width:100%;border-collapse:collapse;text-align:left}.users-table th{background:#252525;padding:1rem;font-weight:600;color:#888;border-bottom:1px solid #333}.users-table td{padding:1rem;border-bottom:1px solid #282828}.user-info{display:flex;flex-direction:column}.user-name{font-weight:600;color:#fff}.user-email{font-size:.85rem;color:#666}.role-select{background:#252525;border:1px solid #444;color:#fff;padding:.4rem .8rem;border-radius:4px;cursor:pointer}.role-select.admin{color:#ff4d4d;border-color:#ff4d4d}.role-select.paid{color:#4dff4d;border-color:#4dff4d}.role-select.free{color:#aaa}.expiry-date{font-size:.9rem;color:#666}.expiry-date.active{color:#4dff4d}.manage-sub-btn{background:#333;border:none;color:#fff;padding:.5rem 1rem;border-radius:4px;cursor:pointer;transition:background .2s}.manage-sub-btn:hover:not(:disabled){background:#444}.manage-sub-btn:disabled{opacity:.3;cursor:not-allowed}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.subscription-modal{background:#1a1a1a;padding:2rem;border-radius:12px;border:1px solid #444;width:400px;box-shadow:0 10px 30px #00000080}.subscription-modal h2{margin-top:0;font-size:1.4rem}.duration-inputs{display:flex;gap:1rem;margin:1.5rem 0}.duration-inputs input{background:#252525;border:1px solid #333;color:#fff;padding:.5rem;border-radius:4px;flex:1}.duration-inputs select{background:#252525;border:1px solid #333;color:#fff;padding:.5rem;border-radius:4px;flex:2}.modal-actions{display:flex;justify-content:flex-end;gap:1rem}.cancel-btn{background:transparent;border:none;color:#888;cursor:pointer}.confirm-btn{background:#0078d4;border:none;color:#fff;padding:.6rem 1.2rem;border-radius:4px;cursor:pointer;font-weight:600}.confirm-btn:hover{background:#0086f1}.toggle-switch{position:relative;display:inline-block;width:42px;height:22px;vertical-align:middle}.toggle-switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:#444;transition:.3s}.slider.round{border-radius:22px}.slider.round:before{border-radius:50%}.slider:before{position:absolute;content:"";height:16px;width:16px;left:3px;bottom:3px;background:#aaa;transition:.3s}input:checked+.slider{background:#0078d4}input:checked+.slider:before{transform:translate(20px);background:#fff}.history-status-text{display:inline-block;vertical-align:middle;margin-left:6px;font-size:.85rem;color:#aaa}.regression-tool-page{padding:2rem 0 4rem;min-height:100vh}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.5rem}.page-header h1{font-size:1.75rem;font-weight:700;margin:.25rem 0;color:var(--color-text-primary)}.page-header p{color:var(--color-text-secondary);margin:0;font-size:.9rem}.header-actions{display:flex;gap:.5rem;flex-shrink:0;margin-top:.25rem}.back-link{color:var(--color-text-muted);text-decoration:none;font-size:.85rem;display:block;margin-bottom:.5rem}.back-link:hover{color:var(--color-text-primary)}.progress-banner{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1rem 1.25rem;margin-bottom:1.75rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap;box-shadow:var(--shadow-sm)}.progress-bar-track{flex:1;min-width:160px;height:8px;background:var(--color-border);border-radius:100px;overflow:hidden}.progress-bar-fill-main{height:100%;background:linear-gradient(90deg,var(--color-success),#6BA67A);border-radius:100px;transition:width .5s ease;min-width:4px}.progress-stats{display:flex;gap:.5rem;flex-wrap:wrap}.stat-pill{padding:.25rem .65rem;border-radius:100px;font-size:.78rem;font-weight:600;border:1px solid}.stat-pill.labeled{background:#4a7c591a;color:var(--color-success);border-color:#4a7c5940}.stat-pill.notindb{background:#c4a35a1a;color:var(--color-warning);border-color:#c4a35a40}.stat-pill.total{background:#3d2b1f0f;color:var(--color-text-secondary);border-color:var(--color-border)}.stat-pill.target{background:#5a7c9c1a;color:var(--color-info);border-color:#5a7c9c40}.regression-layout{display:grid;grid-template-columns:390px 1fr;gap:1.5rem;align-items:start}.panel-left{display:flex;flex-direction:column;gap:1rem;position:sticky;top:1rem}.upload-drop-zone{border:2px dashed var(--color-border-accent);border-radius:var(--radius-lg);padding:2rem 1.5rem;text-align:center;cursor:pointer;background:#fff;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;min-height:140px;box-shadow:var(--shadow-sm)}.upload-drop-zone:hover,.upload-drop-zone.dragging{border-color:var(--color-accent-primary);background:#3d2b1f08;box-shadow:var(--shadow-md)}.upload-drop-zone.uploading{cursor:not-allowed;opacity:.7}.drop-icon{font-size:2.5rem;line-height:1}.drop-title{font-weight:600;color:var(--color-text-primary);margin:0;font-size:.95rem}.drop-hint{color:var(--color-text-muted);font-size:.8rem;margin:0}.active-sample-card{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);transition:box-shadow .3s}.active-sample-card.saved-flash{border-color:var(--color-success);box-shadow:0 0 0 3px #4a7c5933,var(--shadow-md)}.active-sample-image-wrap{background:#f0ede8;display:flex;align-items:center;justify-content:center;padding:1rem;min-height:160px}.active-sample-image-wrap img{max-width:100%;max-height:220px;object-fit:contain;border-radius:var(--radius-md)}.pipeline-preview{padding:.85rem 1rem;border-bottom:1px solid var(--color-border);background:#fdfbf8}.pipeline-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.6rem;font-size:.78rem;color:var(--color-text-muted);font-weight:700;letter-spacing:.06em;text-transform:uppercase}.pipeline-badge{font-size:.72rem;padding:.2rem .55rem;border-radius:100px;font-weight:600;background:var(--color-border);color:var(--color-text-secondary)}.pipeline-badge.running{background:#c4a35a26;color:var(--color-warning)}.pipeline-badge.done{background:#4a7c591f;color:var(--color-success)}.pipeline-badge.error{background:#a854541f;color:var(--color-error)}.pipeline-running-bar{height:3px;background:var(--color-border);border-radius:100px;overflow:hidden;margin-top:.5rem}.pipeline-running-fill{height:100%;background:linear-gradient(90deg,transparent,var(--color-accent-primary),transparent);background-size:200% 100%;animation:shimmer-ltr 1.5s infinite linear;width:100%}@keyframes shimmer-ltr{0%{background-position:200% 0}to{background-position:-200% 0}}.pipeline-matches{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.pipeline-match{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.5rem .65rem;border-radius:var(--radius-md);background:#f5f2ed;border:1px solid var(--color-border)}.pipeline-match.top-match{background:#4a7c590f;border-color:#4a7c594d}.match-left{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}.match-thumb{width:38px;height:38px;object-fit:cover;border-radius:var(--radius-sm);background:var(--color-border);flex-shrink:0;border:1px solid var(--color-border)}.match-info{display:flex;flex-direction:column;gap:1px;min-width:0}.match-rank{font-size:.68rem;color:var(--color-text-muted)}.match-name{font-size:.82rem;font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:195px}.match-score{font-size:.72rem;color:var(--color-text-secondary)}.btn-confirm{padding:.35rem .8rem;border-radius:var(--radius-md);border:none;font-size:.78rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:all .15s;flex-shrink:0;font-family:var(--font-body)}.btn-confirm.primary{background:var(--color-accent-gradient);color:#fff;box-shadow:var(--shadow-sm)}.btn-confirm.primary:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-confirm.secondary{background:#fff;color:var(--color-text-secondary);border:1px solid var(--color-border)}.btn-confirm.secondary:hover{background:var(--color-bg-secondary)}.btn-confirm:disabled{opacity:.45;cursor:not-allowed;transform:none}.pipeline-hint{font-size:.73rem;color:var(--color-text-muted);margin:.5rem 0 0;line-height:1.5}.manual-label-section{padding:.85rem 1rem 1rem}.section-divider{display:flex;align-items:center;gap:.75rem;margin-bottom:.85rem;color:var(--color-text-muted);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;font-weight:700}.section-divider:before,.section-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.checkbox-label{display:flex;align-items:center;gap:.5rem;margin-bottom:.85rem;cursor:pointer;color:var(--color-text-secondary);font-size:.875rem}.search-mfr-box{position:relative}.search-mfr-box input{width:100%;padding:.65rem .85rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:#fff;color:var(--color-text-primary);font-size:.875rem;box-sizing:border-box;font-family:var(--font-body)}.search-mfr-box input:focus{outline:none;border-color:var(--color-accent-primary);box-shadow:0 0 0 3px #3d2b1f1f}.search-mfr-box input::placeholder{color:var(--color-text-muted)}.search-spinner{position:absolute;right:10px;top:10px;font-size:.75rem}.search-dropdown{list-style:none;padding:0;margin:4px 0 0;border:1px solid var(--color-border);border-radius:var(--radius-md);max-height:200px;overflow-y:auto;background:#fff;position:absolute;width:100%;z-index:100;box-shadow:var(--shadow-lg)}.search-dropdown li{padding:.6rem .85rem;cursor:pointer;font-size:.85rem;color:var(--color-text-primary);border-bottom:1px solid var(--color-border);transition:background .12s}.search-dropdown li:last-child{border-bottom:none}.search-dropdown li:hover{background:var(--color-bg-secondary)}.gallery-label{font-size:.78rem;color:var(--color-text-muted);margin:.75rem 0 .5rem;font-weight:600}.mark-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(68px,1fr));gap:6px;margin-bottom:1rem;max-height:260px;overflow-y:auto}.gallery-item{aspect-ratio:1;border:2px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;position:relative;background:var(--color-bg-secondary);transition:border-color .15s}.gallery-item:hover{border-color:var(--color-accent-light)}.gallery-item.selected{border-color:var(--color-accent-primary);box-shadow:0 0 0 2px #3d2b1f33}.gallery-item img{width:100%;height:100%;object-fit:contain;padding:2px}.gallery-check{position:absolute;top:2px;right:4px;color:var(--color-accent-primary);font-size:.85rem;font-weight:700;text-shadow:0 0 4px #fff}.save-btn{width:100%;margin-top:.25rem}.panel-right{min-width:0}.panel-header-row{margin-bottom:1rem}.filter-tabs{display:flex;gap:.4rem;flex-wrap:wrap}.filter-tab{padding:.35rem .9rem;border-radius:100px;border:1px solid var(--color-border);background:#fff;color:var(--color-text-secondary);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s;font-family:var(--font-body)}.filter-tab:hover{background:var(--color-bg-secondary);color:var(--color-text-primary);border-color:var(--color-border-accent)}.filter-tab.active{background:var(--color-accent-primary);border-color:var(--color-accent-primary);color:#fff}.sample-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem}.sample-card{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;transition:all .2s;box-shadow:var(--shadow-sm)}.sample-card:hover{border-color:var(--color-border-accent);box-shadow:var(--shadow-md);transform:translateY(-1px)}.sample-card.active{border-color:var(--color-accent-primary);box-shadow:0 0 0 2px #3d2b1f26,var(--shadow-md)}.sample-card-image{position:relative;aspect-ratio:1;background:var(--color-bg-secondary);cursor:pointer;overflow:hidden}.sample-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .2s}.sample-card-image:hover img{transform:scale(1.06)}.status-dot{position:absolute;top:5px;right:5px;width:8px;height:8px;border-radius:50%;border:1.5px solid rgba(255,255,255,.85)}.status-dot.labeled{background:var(--color-success)}.status-dot.pending_label{background:var(--color-warning)}.sample-card-body{padding:.5rem .6rem;display:flex;flex-direction:column;gap:3px}.sample-mfr{font-size:.73rem;color:var(--color-text-secondary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3;font-weight:500}.not-in-db-tag{color:var(--color-warning);font-style:normal;font-weight:700}.unlabeled-tag{color:var(--color-text-muted);font-style:italic}.rank-pill{font-size:.68rem;font-weight:700;padding:.1rem .45rem;border-radius:100px;display:inline-block;border:1px solid}.rank-pill.hit{background:#4a7c591a;color:var(--color-success);border-color:#4a7c5940}.rank-pill.miss{background:#a854541a;color:var(--color-error);border-color:#a8545440}.rank-pill.partial{background:#c4a35a1a;color:var(--color-warning);border-color:#c4a35a40}.sample-card-actions{display:flex;gap:.25rem;margin-top:2px}.btn-icon-sm{background:none;border:none;cursor:pointer;font-size:.85rem;line-height:1;padding:.15rem .3rem;border-radius:var(--radius-sm);opacity:.6;transition:opacity .15s,background .15s}.btn-icon-sm:hover{opacity:1;background:var(--color-bg-secondary)}.btn-icon-sm.danger:hover{background:#a854541a}.empty-state{text-align:center;padding:3rem 1rem;color:var(--color-text-muted);background:#fff;border-radius:var(--radius-lg);border:1px dashed var(--color-border)}.empty-state span{font-size:2.5rem;display:block;margin-bottom:.75rem}.empty-state p{font-size:.875rem;margin:0;color:var(--color-text-muted)}.btn.btn-primary{background:var(--color-accent-gradient);color:#fff}.btn.btn-secondary{background:#fff;color:var(--color-text-primary);border:1px solid var(--color-border-accent)}.btn.btn-secondary:hover{background:var(--color-bg-secondary)}.btn.btn-sm{font-size:.78rem;padding:.35rem .85rem}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important;box-shadow:none!important}.spinner{width:28px;height:28px;border:3px solid var(--color-border);border-top-color:var(--color-accent-primary);border-radius:50%;animation:spin .8s linear infinite;display:block}.spinner.small{width:18px;height:18px;border-width:2px}@media (max-width: 900px){.regression-layout{grid-template-columns:1fr}.panel-left{position:static}}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:var(--spacing-md)}.loading-spinner{width:48px;height:48px;border:3px solid var(--color-border);border-top-color:var(--color-gold-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}:root{--color-bg-primary: #E8E4DE;--color-bg-secondary: #F5F2ED;--color-bg-card: #FFFFFF;--color-bg-glass: rgba(255, 255, 255, .95);--color-bg-hallmark: #2C3E50;--color-accent-primary: #3D2B1F;--color-accent-light: #6B5B4F;--color-accent-dark: #2A1D14;--color-accent-gradient: linear-gradient(135deg, #3D2B1F 0%, #5C4434 50%, #3D2B1F 100%);--color-text-primary: #3D2B1F;--color-text-secondary: #6B5B4F;--color-text-muted: #9A8B7D;--color-text-accent: #3D2B1F;--color-success: #4A7C59;--color-warning: #C4A35A;--color-error: #A85454;--color-info: #5A7C9C;--color-border: rgba(61, 43, 31, .2);--color-border-accent: rgba(61, 43, 31, .4);--font-display: "Playfair Display", Georgia, serif;--font-body: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(61, 43, 31, .1);--shadow-md: 0 4px 6px rgba(61, 43, 31, .15);--shadow-lg: 0 10px 25px rgba(61, 43, 31, .2);--shadow-accent: 0 0 20px rgba(61, 43, 31, .15);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-body);background-color:var(--color-bg-primary);color:var(--color-text-primary);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:600;line-height:1.3;color:var(--color-text-primary)}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.5rem}h4{font-size:1.25rem}p{color:var(--color-text-secondary);margin-bottom:var(--spacing-md)}a{color:var(--color-accent-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-accent-light)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);font-family:var(--font-body);font-size:1rem;font-weight:500;border:none;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-normal)}.btn-primary{background:var(--color-accent-gradient);color:#fff;box-shadow:var(--shadow-accent)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 30px #3d2b1f4d}.btn-secondary{background:transparent;color:var(--color-accent-primary);border:1px solid var(--color-border-accent)}.btn-secondary:hover{background:#3d2b1f14}.form-group{margin-bottom:var(--spacing-lg)}.form-label{display:block;margin-bottom:var(--spacing-sm);font-size:.875rem;font-weight:500;color:var(--color-text-secondary)}.form-input{width:100%;padding:var(--spacing-md);font-family:var(--font-body);font-size:1rem;color:var(--color-text-primary);background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-fast)}.form-input:focus{outline:none;border-color:var(--color-accent-primary);box-shadow:0 0 0 3px #3d2b1f26}.form-input::placeholder{color:var(--color-text-muted)}.card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.card-glass{background:var(--color-bg-glass);border:1px solid var(--color-border-accent);box-shadow:var(--shadow-lg)}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--spacing-lg)}.page{min-height:100vh;padding:var(--spacing-2xl) 0}.center{display:flex;flex-direction:column;align-items:center;justify-content:center}.text-accent{color:var(--color-accent-primary)}.text-center{text-align:center}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.mb-xl{margin-bottom:var(--spacing-xl)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}.fade-in{animation:fadeIn var(--transition-slow) ease-out}@media (max-width: 768px){h1{font-size:2rem}h2{font-size:1.5rem}.container{padding:0 var(--spacing-md)}:root{--spacing-lg: 1rem;--spacing-xl: 1.5rem}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-spinner{width:40px;height:40px;border:3px solid rgba(61,43,31,.15);border-top:3px solid var(--color-accent-primary);border-radius:50%;animation:spin 1s linear infinite}.loading-spinner.small{width:20px;height:20px;border-width:2px}.loading-spinner.large{width:60px;height:60px;border-width:4px}
