*{margin:0;padding:0}body{-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#1a472a,#2d5016 50%,#0d2818);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;padding:20px}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;background:linear-gradient(160deg,#0f2e1a,#1a472a 40%,#0d1f13);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0}.App,body{min-height:100vh}.App{align-items:flex-start;display:flex;justify-content:center;padding:16px 10px}.container{background:#faf8f2;border-radius:20px;box-shadow:0 20px 60px #00000080;max-width:980px;padding:28px 24px;width:100%}h1{color:#1a472a;display:flex;font-size:1.7rem;gap:10px;letter-spacing:-.5px;margin:0 0 2px}h1,h1:before{align-items:center;font-weight:800}h1:before{background:linear-gradient(135deg,#c5a44e,#a8893a);border-radius:10px;color:#fff;content:"$";display:inline-flex;flex-shrink:0;font-size:1.2rem;height:36px;justify-content:center;width:36px}.subtitle{color:#8a9b87;font-size:.82rem;font-weight:500;margin:0 0 20px;padding-left:46px}.message{animation:slideIn .3s ease;border-left:4px solid #0000;border-radius:10px;font-size:.88rem;font-weight:500;margin-bottom:16px;padding:12px 16px}.message.success{background:#e8f5e9;border-left-color:#2e7d32;color:#1b5e20}.message.error{background:#fce4ec;border-left-color:#c62828;color:#b71c1c}.message.info{background:#e3f2fd;border-left-color:#1565c0;color:#0d47a1}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.collection-header{margin-bottom:14px}.header-top{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.collection-header h2{color:#1a472a;font-size:1.25rem;font-weight:700;margin:0}.collection-count{color:#8a9b87;font-size:.8rem;margin-top:2px}.header-secondary{align-items:center;display:flex;gap:8px}.header-divider{color:#d0ccc0;font-size:.8rem}.btn-text{background:none;border:none;color:#c5a44e;cursor:pointer;font-family:inherit;font-size:.82rem;font-weight:700;padding:4px 0;text-decoration:underline;text-underline-offset:2px;transition:color .2s}.btn-text:hover{color:#a8893a}.btn-text:disabled{cursor:not-allowed;opacity:.5}.btn-add{font-size:.88rem;padding:10px 20px;white-space:nowrap}.stats-bar{background:linear-gradient(135deg,#1a472a,#0f2e1a);border-radius:12px;box-shadow:0 4px 16px #00000026;display:grid;grid-template-columns:repeat(5,1fr);margin-bottom:14px;padding:14px 8px}.stat{position:relative;text-align:center}.stat:not(:last-child):after{background:#ffffff1a;content:"";height:70%;position:absolute;right:0;top:15%;width:1px}.stat-value{color:#c5a44e;display:block;font-size:1.15rem;font-weight:800;line-height:1.2}.stat-label{color:#ffffff80;display:block;font-size:.62rem;font-weight:600;letter-spacing:.6px;margin-top:3px;text-transform:uppercase}.search-filter-bar{margin-bottom:16px}.search-row{align-items:center;display:flex;gap:8px}.search-input{background:#fff;border:1.5px solid #e0dbd0;border-radius:10px;color:#333;flex:1 1;font-family:inherit;font-size:.9rem;min-width:0;padding:10px 14px;transition:all .2s}.search-input::placeholder{color:#bbb}.search-input:focus{border-color:#1a472a;box-shadow:0 0 0 3px #1a472a14;outline:none}.sort-select{background:#fff;border:1.5px solid #e0dbd0;border-radius:10px;color:#333;cursor:pointer;font-size:.82rem;padding:10px 12px;white-space:nowrap}.sort-select:focus{border-color:#1a472a;outline:none}.btn-filter-toggle{background:#fff;border:1.5px solid #e0dbd0;border-radius:10px;color:#666;cursor:pointer;font-size:.82rem;font-weight:600;padding:10px 14px;transition:all .15s;white-space:nowrap}.btn-filter-toggle:hover{border-color:#1a472a;color:#1a472a}.btn-filter-toggle.active{background:#1a472a;border-color:#1a472a;color:#fff}.filter-panel{background:#f5f2eb;border:1.5px solid #e0dbd0;border-radius:12px;margin-top:10px;padding:14px 16px}.filter-row{display:flex;gap:12px;margin-bottom:10px}.filter-group{flex:1 1;min-width:0}.filter-group label{color:#8a9b87;display:block;font-size:.72rem;font-weight:700;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.filter-group select{background:#fff;border:1.5px solid #e0dbd0;border-radius:8px;color:#333;font-size:.85rem;padding:8px 10px;width:100%}.filter-group select:focus{border-color:#1a472a;outline:none}.filter-toggles{flex-wrap:wrap;gap:8px}.filter-chip,.filter-toggles{align-items:center;display:flex}.filter-chip{background:#fff;border:1.5px solid #e0dbd0;border-radius:20px;color:#555;cursor:pointer;font-size:.8rem;font-weight:600;gap:5px;padding:6px 12px;transition:all .15s;-webkit-user-select:none;user-select:none}.filter-chip:has(input:checked){background:#1a472a;border-color:#1a472a;color:#fff}.filter-chip input{display:none}.btn-clear-filters{background:none;border:none;color:#c5a44e;cursor:pointer;font-size:.8rem;font-weight:600;padding:6px 12px;text-decoration:underline}@media (max-width:768px){.search-row{flex-wrap:wrap}.search-input{width:100%}.btn-filter-toggle,.sort-select{flex:1 1}.filter-row{flex-direction:column;gap:8px}}.notes-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.note-card{background:#fff;border:1px solid #eae5da;border-radius:14px;box-shadow:0 2px 8px #0000000a;cursor:pointer;overflow:hidden;transition:all .25s ease}.note-card:hover{border-color:#c5a44e;box-shadow:0 12px 32px #0000001f;transform:translateY(-4px)}.note-card:active{transform:scale(.98)}.card-photo{align-items:center;background:#f0ece0;display:flex;height:200px;justify-content:center;overflow:hidden;width:100%}.card-photo img{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.note-card:hover .card-photo img{transform:scale(1.03)}.card-photo.placeholder{background:linear-gradient(135deg,#1a472a,#2d6b3e);position:relative}.card-photo.placeholder:after{background:repeating-linear-gradient(45deg,#0000,#0000 20px,#ffffff05 0,#ffffff05 40px);content:"";inset:0;position:absolute}.card-photo.placeholder span{color:#c5a44e;font-size:2.2rem;font-weight:800;text-shadow:0 2px 8px #0003;z-index:1}.card-info{padding:14px 16px}.card-title{align-items:center;color:#1a472a;display:flex;font-size:.95rem;font-weight:700;gap:8px;margin-bottom:4px}.card-type{color:#8b7a3e;font-style:italic;font-weight:500}.card-serial,.card-type{font-size:.78rem;margin-bottom:3px}.card-serial{color:#888;font-family:SF Mono,Fira Code,Courier New,monospace;letter-spacing:.3px}.card-friedberg{color:#8b7a3e;margin-bottom:3px}.card-friedberg,.card-grade{font-size:.78rem;font-weight:600}.card-grade{color:#2d5016;margin-bottom:6px}.card-flags{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:6px}.card-value{color:#1a472a;font-size:1.05rem;font-weight:800;margin-top:4px}.flag-tag,.flag-tag-sm{background:#f5f0df;border-radius:5px;color:#7a6b30;display:inline-block;font-weight:600}.flag-tag{font-size:.8rem;padding:4px 10px}.flag-tag-sm{font-size:.7rem;padding:2px 7px}.star-badge,.star-badge-sm{background:linear-gradient(135deg,#c5a44e,#a8893a);border-radius:5px;color:#fff;font-weight:700;letter-spacing:.3px}.star-badge{font-size:.8rem;padding:4px 10px}.star-badge-sm{font-size:.68rem;padding:2px 7px}.empty-state{color:#8a9b87;padding:48px 20px;text-align:center}.empty-icon{color:#c5a44e;font-size:3.5rem;font-weight:800;margin-bottom:12px}.empty-state h3{color:#1a472a;font-weight:700;margin-bottom:8px}.empty-state p{font-size:.9rem;margin-bottom:20px}.add-form h2{color:#1a472a;font-size:1.3rem;font-weight:700;margin:0 0 6px}.form-subtitle{color:#8a9b87;font-size:.85rem;line-height:1.5;margin-bottom:24px}.section{border-bottom:1px solid #ece7db;margin-bottom:24px;padding-bottom:24px}.section:last-of-type{border-bottom:none}.section h3{color:#1a472a;font-size:.95rem;font-weight:700;margin-bottom:14px}.form-row{align-items:flex-end;display:flex;gap:12px;margin-bottom:12px}.form-group{display:flex;flex:1 1;flex-direction:column}label{color:#777;display:block;font-size:.78rem;font-weight:600;letter-spacing:.3px;margin-bottom:5px;text-transform:uppercase}input,select,textarea{background:#fff;border:1.5px solid #e0dbd0;border-radius:8px;color:#333;font-family:inherit;font-size:.92rem;padding:10px 12px;transition:all .2s;width:100%}input::placeholder,textarea::placeholder{color:#bbb}input:focus,select:focus,textarea:focus{border-color:#1a472a;box-shadow:0 0 0 3px #1a472a14;outline:none}textarea{min-height:56px;resize:vertical}.photo-upload-row{display:flex;gap:12px}.photo-upload-area{flex:1 1;margin-bottom:8px}.photo-side-label{color:#1a472a;display:block;font-size:.78rem;font-weight:700;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}.upload-label{cursor:pointer;display:block}.upload-placeholder{align-items:center;background:#c5a44e08;border:2px dashed #c5a44e;border-radius:12px;color:#8b7a3e;display:flex;flex-direction:column;font-size:.88rem;gap:6px;padding:28px 16px;text-align:center;transition:all .25s}.upload-placeholder:hover{background:#c5a44e14;border-color:#a8893a}.upload-icon{align-items:center;background:#c5a44e1a;border-radius:50%;display:flex;font-size:1.8rem;font-weight:300;height:42px;justify-content:center;width:42px}.upload-hint{color:#aaa;font-size:.72rem}.photo-preview{display:inline-block;position:relative}.photo-preview img{border:1.5px solid #e0dbd0;border-radius:10px;box-shadow:0 4px 12px #00000014;max-height:280px;max-width:100%}.scanning-overlay{align-items:center;animation:pulse 1.5s ease-in-out infinite;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f2e1abf;border-radius:10px;bottom:0;color:#c5a44e;display:flex;font-size:1rem;font-weight:700;justify-content:center;left:0;letter-spacing:1.5px;position:absolute;right:0;text-transform:uppercase;top:0}@keyframes pulse{0%,to{opacity:.7}50%{opacity:1}}.btn-remove-photo{background:#0000;border:1px solid #dc3545;border-radius:6px;color:#dc3545;cursor:pointer;display:block;font-family:inherit;font-size:.78rem;font-weight:600;margin:8px auto 0;padding:6px 14px;transition:all .2s}.btn-remove-photo:hover{background:#dc3545;color:#fff}.error-grid{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.error-checkbox{align-items:center;background:#fff;border:1px solid #e0dbd0;border-radius:8px;color:#666;cursor:pointer;display:flex;font-size:.82rem;gap:6px;padding:8px 12px;transition:all .2s}.error-checkbox:hover{background:#f8f8f5;border-color:#1a472a}.error-checkbox.checked{background:#e8f5e9;border-color:#2e7d32;color:#1b5e20;font-weight:600}.error-checkbox input{display:none}.btn-back,.btn-danger,.btn-export,.btn-primary,.btn-secondary{border:none;border-radius:10px;cursor:pointer;font-family:inherit;font-size:.9rem;font-weight:700;padding:11px 22px;transition:all .2s}.btn-primary{background:linear-gradient(135deg,#1a472a,#2d6b3e);box-shadow:0 3px 10px #1a472a40;color:#fff}.btn-primary:hover:not(:disabled){box-shadow:0 6px 18px #1a472a59;filter:brightness(1.05)}.btn-primary:active:not(:disabled){transform:scale(.97)}.btn-secondary{background:#fff;border:2px solid #1a472a;color:#1a472a}.btn-secondary:hover:not(:disabled){background:#1a472a;color:#fff}.btn-export{background:#0000;border:1.5px solid #d5d0c0;color:#1a472a;padding:9px 18px}.btn-export:hover:not(:disabled){background:#f0f5f1;border-color:#1a472a}.btn-back{background:#0000;color:#8a9b87;margin-bottom:12px;padding:6px 0}.btn-back:hover{color:#1a472a}.btn-danger{background:#0000;border:1.5px solid #dc3545;color:#dc3545}.btn-danger:hover{background:#dc3545;color:#fff}.btn-export:disabled,.btn-primary:disabled,.btn-secondary:disabled{cursor:not-allowed;opacity:.5}.actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.detail-header{align-items:center;display:flex;gap:12px;margin-bottom:20px}.detail-header h2{color:#1a472a;font-size:1.3rem;font-weight:700;margin:0}.detail-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr;margin-bottom:24px}.detail-photos{display:flex;flex-direction:column;gap:12px}.photo-label{color:#8a9b87;display:block;font-size:.7rem;font-weight:700;letter-spacing:.8px;margin-bottom:4px;text-transform:uppercase}.detail-photo{border:1.5px solid #e8e3d8;border-radius:12px;box-shadow:0 3px 10px #0000000f;overflow:hidden}.detail-photo img{display:block;width:100%}.detail-info{display:flex;flex-direction:column;gap:20px}.info-section h3{color:#8a9b87;font-size:.72rem;font-weight:700;letter-spacing:1px;margin-bottom:8px;text-transform:uppercase}.info-row{border-bottom:1px solid #f0ece0;display:flex;font-size:.88rem;justify-content:space-between;padding:7px 0}.info-row span:first-child{color:#999;font-weight:500}.info-row span:last-child{color:#333;font-weight:600}.flags-list{display:flex;flex-wrap:wrap;gap:6px}.detail-footer{align-items:center;border-top:1px solid #ece7db;display:flex;justify-content:space-between;padding-top:20px}.date-added{color:#b0a990;font-size:.8rem;font-weight:500}@media (max-width:768px){.App{padding:8px 6px}.container{border-radius:16px;padding:20px 16px}h1{font-size:1.4rem}h1:before{border-radius:8px;font-size:1rem;height:32px;width:32px}.subtitle{font-size:.78rem;margin-bottom:16px;padding-left:42px}.form-row{flex-direction:column;gap:0}.stats-bar{gap:0;grid-template-columns:repeat(5,1fr);padding:12px 6px}.stat-value{font-size:1rem}.stat-label{font-size:.58rem}.detail-grid{grid-template-columns:1fr}.photo-upload-row{flex-direction:column}.notes-grid{grid-template-columns:1fr}.card-photo{height:220px}.actions{flex-direction:column}.btn-danger,.btn-primary,.btn-secondary{text-align:center;width:100%}.error-grid{grid-template-columns:1fr 1fr}}.crop-modal{background:#000;display:flex;flex-direction:column;inset:0;position:fixed;z-index:1000}.crop-container{flex:1 1;position:relative}.crop-controls{background:#111;display:flex;flex-direction:column;gap:14px;padding:16px 20px}.crop-zoom-label{align-items:center;color:#aaa;display:flex;font-size:.82rem;font-weight:600;gap:12px}.crop-zoom{appearance:none;background:#444;border-radius:2px;flex:1 1;height:4px;outline:none}.crop-zoom::-webkit-slider-thumb{-webkit-appearance:none;background:#c5a44e;border-radius:50%;cursor:pointer;height:22px;width:22px}.crop-actions{display:flex;gap:12px}.crop-actions .btn-secondary{background:#222;border-color:#555;color:#fff;flex:1 1}.crop-actions .btn-secondary:hover{background:#333}.crop-actions .btn-primary{flex:1 1}.crop-sliders{display:flex;flex-direction:column;gap:10px}.crop-rotation-value{color:#c5a44e;font-size:.82rem;min-width:36px;text-align:right}.crop-rotate-buttons{display:flex;gap:10px}.btn-rotate{background:#333;border:1px solid #555;border-radius:8px;color:#fff;cursor:pointer;flex:1 1;font-size:.82rem;font-weight:600;padding:8px 12px;transition:background .15s}.btn-rotate:hover{background:#444}.batch-view h2{color:#1a472a;font-size:1.3rem;font-weight:700;margin:0 0 6px}.batch-photo-wrap{border-radius:12px;margin-bottom:20px;overflow:hidden;position:relative}.batch-photo-img{border:1.5px solid #e0dbd0;border-radius:12px;display:block;width:100%}.batch-results h3{color:#1a472a;font-size:1rem;font-weight:700;margin:20px 0 12px}.batch-note-card{background:#fff;border:1.5px solid #e0dbd0;border-radius:12px;margin-bottom:10px;padding:14px 16px;transition:all .2s}.batch-note-card:not(.batch-note-excluded){border-color:#1a472a}.batch-note-excluded{opacity:.5}.batch-note-header{align-items:center;display:flex;justify-content:space-between}.batch-note-check{align-items:center;color:#1a472a;cursor:pointer;display:flex;font-size:.9rem;font-weight:700;gap:8px}.batch-note-check input{accent-color:#1a472a;height:18px;width:18px}.batch-note-summary{color:#8a9b87;font-size:.85rem;font-weight:600}.batch-note-fields{border-top:1px solid #f0ece0;margin-top:12px;padding-top:12px}.batch-note-fields .form-row{margin-bottom:8px}.batch-note-fields input{font-size:.88rem;padding:8px 10px}.btn-batch{font-size:.82rem;padding:10px 14px}.fab-add{animation:fab-pulse 2.5s ease-in-out infinite;background:linear-gradient(135deg,#c5a44e,#9e7e2e);border:none;border-radius:60px;bottom:24px;box-shadow:0 8px 30px #c5a44e80,0 3px 10px #00000059;color:#fff;cursor:pointer;font-size:1.15rem;font-weight:800;left:50%;letter-spacing:.5px;padding:18px 44px;position:fixed;text-transform:uppercase;transform:translateX(-50%);transition:all .2s;z-index:100}.fab-add:hover{box-shadow:0 10px 36px #c5a44e99,0 5px 14px #00000059;transform:translateX(-50%) translateY(-2px)}.fab-add:active{transform:translateX(-50%) translateY(0)}@keyframes fab-pulse{0%,to{box-shadow:0 8px 30px #c5a44e80,0 3px 10px #00000059}50%{box-shadow:0 8px 40px #c5a44eb3,0 3px 14px #0006}}.batch-photos-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr;margin-bottom:16px}.batch-photo-col h4{color:#1a472a;font-size:.88rem;font-weight:700;margin:0 0 8px}.optional-label{color:#8a9b87;font-size:.78rem;font-weight:400}.upload-disabled{opacity:.45;pointer-events:none}@media (max-width:768px){.batch-photos-row{grid-template-columns:1fr}}@media (max-width:380px){.stats-bar{grid-template-columns:repeat(3,1fr)}.stat:nth-child(4),.stat:nth-child(5){margin-top:8px}.stat:nth-child(3):after{display:none}.error-grid{grid-template-columns:1fr}}
/*# sourceMappingURL=main.1ae67f3d.css.map*/