:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#ffffffe6;background-color:#121212;--primary-color: #6366f1;--bg-card: #1e1e1e;--border-color: #333}*,*:before,*:after{box-sizing:border-box}body{margin:0;display:block;min-width:320px;min-height:100vh;background-color:#121212;overflow-x:hidden}#root{width:100%}.container{width:100%;height:100vh;display:flex;flex-direction:column;padding:0}header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;border-bottom:1px solid var(--border-color);background:#161616}h1{font-size:1.5em;font-weight:600;background:linear-gradient(to right,#fff,#aaa);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin:0}.filter-bar{display:flex;gap:1rem;align-items:center;padding:.8rem 2rem;border-bottom:1px solid var(--border-color);background:#1a1a1a;flex-wrap:wrap}.search-input{flex:1;min-width:200px;background:#1e1e1e;border:1px solid var(--border-color);padding:.6rem 1rem;border-radius:6px;color:#fff;font-size:.95rem;transition:border-color .2s}.search-input:focus{outline:none;border-color:var(--primary-color)}.search-input::placeholder{color:#666}.filter-select{background:#1e1e1e;border:1px solid var(--border-color);padding:.6rem 1rem;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;transition:border-color .2s}.filter-select:focus{outline:none;border-color:var(--primary-color)}.filter-btn{background:#1e1e1e;border:1px solid var(--border-color);padding:.6rem 1rem;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;transition:all .2s;white-space:nowrap}.filter-btn:hover{background:#333;border-color:var(--primary-color)}.filter-btn.active{background:#be123c;border-color:#be123c}.results-count{color:#888;font-size:.9rem;margin-left:auto;white-space:nowrap}.upload-btn{background-color:var(--primary-color);color:#fff;padding:.8em 1.5em;border-radius:6px;border:none;cursor:pointer;font-weight:600;transition:all .2s}.upload-btn:hover{background-color:#2563eb;transform:translateY(-1px)}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem}.photo-card{background-color:var(--bg-card);border-radius:8px;overflow:hidden;border:1px solid var(--border-color);transition:transform .2s;position:relative;aspect-ratio:1}.photo-card:hover{transform:scale(1.02);border-color:#555}.photo-img{width:100%;height:100%;object-fit:cover;display:block}.type-badge{background:#000000b3;color:#fff;font-size:.6rem;font-weight:900;padding:1px 4px;border-radius:3px;text-transform:uppercase;letter-spacing:.05em;border:1px solid rgba(255,255,255,.15);pointer-events:none;font-family:Inter,sans-serif}.empty-state{text-align:center;padding:4rem;color:#666}.app-layout{display:flex;flex:1;overflow:hidden;gap:0;background:#1a1a1a;position:relative}.folders-sidebar{width:280px;background:#161616;border-right:1px solid var(--border-color);padding:1rem;overflow-y:auto;flex-shrink:0;height:100%;position:relative;top:0}.main-content{flex:1;min-width:0;overflow-y:auto;padding:2rem;background:#121212}.inspector-panel{width:380px;background-color:#161616f2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-left:1px solid var(--border-color);padding:1.5rem;overflow-y:auto;display:flex;flex-direction:column;gap:1.5rem;position:absolute;top:0;right:0;bottom:0;z-index:1000;box-shadow:-5px 0 30px #00000080;animation:slideInRight .3s ease-out}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideInLeft{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}.inspector-image{width:100%;aspect-ratio:1;object-fit:contain;background-color:#000;border-radius:4px;border:1px solid var(--border-color)}.meta-group{display:flex;flex-direction:column;gap:.5rem}.meta-label{font-size:.8rem;color:#888;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.meta-value{font-family:monospace;background:#111;padding:.5rem;border-radius:4px;word-break:break-all;font-size:.9rem}.rating-stars{display:flex;gap:5px;cursor:pointer}.star{font-size:1.5rem;color:#444;transition:color .2s}.star.active{color:#fbbf24}.star:hover{color:#fcd34d}.favorite-btn{background:none;border:1px solid var(--border-color);color:#fff;padding:.5rem 1rem;border-radius:4px;cursor:pointer;display:flex;align-items:center;gap:.5rem;justify-content:center;transition:all .2s}.favorite-btn.active{background-color:#be123c;border-color:#be123c}.favorite-btn:hover{background-color:#333}.favorite-btn.active:hover{background-color:#9f1239}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#121212}::-webkit-scrollbar-thumb{background:#333;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#555}.photo-card.selected{border-color:var(--primary-color);box-shadow:0 0 0 2px var(--primary-color);z-index:10}.folder-item{padding:.6rem;border-radius:4px;cursor:pointer;transition:all .2s;margin-bottom:.3rem;display:flex;justify-content:space-between;align-items:center;font-size:.9rem}.folder-item:hover{background:#2a2a2a}.folder-item.active{background:var(--primary-color);color:#fff}.folder-count-badge{background:#ffffff14;color:#888;padding:.1rem .5rem;border-radius:12px;font-size:.75rem;font-weight:600;min-width:1.8rem;text-align:center;transition:all .2s;border:1px solid transparent}.folder-item:hover .folder-count-badge{background:#ffffff26;color:#aaa}.folder-item.active .folder-count-badge{background:#0003;color:#fff;border-color:#ffffff1a}.delete-folder-btn{background:transparent;border:none;cursor:pointer;opacity:0;transition:opacity .2s;font-size:1rem}.folder-item:hover .delete-folder-btn{opacity:1}.delete-folder-btn:hover{transform:scale(1.2)}.icon-btn{background:transparent;border:1px solid var(--border-color);color:#fff;padding:.3rem .6rem;border-radius:4px;cursor:pointer;font-size:1rem;transition:all .2s}.icon-btn:hover{background:#333;border-color:var(--primary-color)}.modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#1e1e1e;padding:2rem;border-radius:8px;border:1px solid var(--border-color);min-width:400px}.modal-content h3{margin-top:0;color:#fff}.primary-btn{background:var(--primary-color);color:#fff;border:none;padding:.6rem 1.2rem;border-radius:4px;cursor:pointer;font-size:.95rem;transition:all .2s}.primary-btn:hover{background:#4a90e2}.secondary-btn{background:transparent;color:#fff;border:1px solid var(--border-color);padding:.6rem 1.2rem;border-radius:4px;cursor:pointer;font-size:.95rem;transition:all .2s}.secondary-btn:hover{background:#333}.icon-btn-small{background:transparent;border:1px solid var(--border-color);color:#fff;padding:.1rem .4rem;border-radius:3px;cursor:pointer;font-size:.8rem;transition:all .2s;opacity:0}.folder-item:hover .icon-btn-small{opacity:1}.icon-btn-small:hover{background:var(--primary-color);border-color:var(--primary-color)}.delete-photo-btn{background:#8b0000;color:#fff;border:none;padding:.6rem 1rem;border-radius:4px;cursor:pointer;font-size:.95rem;transition:all .2s;width:100%}.delete-photo-btn:hover{background:#a00000;transform:translateY(-1px);box-shadow:0 2px 8px #8b00004d}.delete-photo-btn:active{transform:translateY(0)}.exif-container{background:#111;border-radius:6px;padding:1rem;border:1px solid #333}.exif-primary{margin-bottom:1rem;border-bottom:1px solid #222;padding-bottom:.5rem}.exif-main-val{font-size:1.1rem;font-weight:600;color:#fff}.exif-sub-val{font-size:.85rem;color:#888;margin-top:.2rem}.exif-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;margin-bottom:1rem}.exif-item{background:#1a1a1a;padding:.5rem;border-radius:4px;display:flex;flex-direction:column}.exif-tag{font-size:.7rem;color:#666;text-transform:uppercase;font-weight:700}.exif-val{font-size:.9rem;color:#ddd;font-family:monospace}.exif-details{border-top:1px solid #222;padding-top:.5rem}.exif-details summary{font-size:.8rem;color:var(--primary-color);cursor:pointer;outline:none;list-style:none}.exif-details summary::-webkit-details-marker{display:none}.exif-list{margin-top:.5rem;font-size:.75rem;color:#777;max-height:150px;overflow-y:auto}.exif-list-item{margin-bottom:.2rem;padding:.2rem 0;border-bottom:1px solid #1a1a1a}.exif-list-item .label{color:#555;font-weight:600}.lightbox-overlay{position:fixed;inset:0;background:#000000f2;display:flex;align-items:center;justify-content:center;z-index:1000;cursor:default;animation:fadeIn .15s ease-out;transition:all .3s ease-out}.lightbox-image-container{display:flex;align-items:center;justify-content:center;width:100%;height:100%;transition:all .3s ease-out}.lightbox-image{max-width:90vw;max-height:90vh;object-fit:contain;box-shadow:0 0 50px #000c;border:1px solid #333;cursor:default;animation:zoomIn .2s ease-out}.lightbox-actions{position:absolute;top:1.5rem;right:1.5rem;display:flex;gap:1rem;z-index:1001}.lightbox-close{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;width:36px;height:36px;border-radius:50%;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.lightbox-close:hover{background:#fff3;transform:rotate(90deg)}.lightbox-close:hover{background:#fff3;transform:scale(1.1)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes zoomIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.upload-panel{position:fixed;bottom:1.5rem;right:1.5rem;background:#1e1e1e;border:1px solid #333;border-radius:8px;box-shadow:0 8px 30px #00000080;z-index:2000;display:flex;flex-direction:column;overflow:visible;animation:slideUp .3s ease-out}.upload-panel-resize-handle{position:absolute;top:0;left:0;width:20px;height:20px;cursor:nwse-resize;z-index:2001;background:linear-gradient(135deg,var(--primary-color) 30%,transparent 30%);border-top-left-radius:8px;opacity:.4;transition:opacity .2s}.upload-panel-resize-handle:hover{opacity:1}@keyframes slideUp{0%{transform:translateY(100px);opacity:0}to{transform:translateY(0);opacity:1}}.upload-panel-header{padding:.8rem 1rem;background:#252525;border-bottom:1px solid #333;display:flex;justify-content:space-between;align-items:center;font-size:.9rem;font-weight:600}.upload-panel-body{flex:1;overflow-y:auto;padding:.5rem;min-height:100px}.upload-panel-body::-webkit-scrollbar{width:6px}.upload-panel-body::-webkit-scrollbar-track{background:transparent}.upload-panel-body::-webkit-scrollbar-thumb{background:#333;border-radius:10px}.upload-panel-body::-webkit-scrollbar-thumb:hover{background:#444}.upload-item{display:flex;align-items:center;gap:.8rem;padding:.5rem;font-size:.8rem;border-bottom:1px solid #2a2a2a}.upload-item:last-child{border-bottom:none}.upload-item-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#ccc}.upload-item-status{font-size:.75rem;color:#888}.upload-panel-footer{padding:.8rem 1rem;background:#252525;display:flex;gap:.5rem}.progress-container{width:100%;height:4px;background:#333;border-radius:2px;margin-top:.4rem;overflow:hidden}.progress-fill{height:100%;background:var(--primary-color);transition:width .3s ease}.status-icon{width:16px;height:16px;display:flex;align-items:center;justify-content:center}.status-icon.success{color:#4caf50}.status-icon.error{color:#f44336}.status-icon.loading{border:2px solid #555;border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.context-menu-item:hover{background-color:#3a3a3a!important}.kbd{background-color:#333;border:1px solid #555;border-radius:4px;padding:.1rem .4rem;font-family:monospace;font-size:.85rem;box-shadow:0 2px #111;color:#eee}.panel-focused{outline:2px solid var(--primary-color);outline-offset:-2px;box-shadow:inset 0 0 10px #3b82f633}.folder-item.drag-over{background:#4a90e233!important;border:1px dashed #4a90e2!important}.drop-overlay{position:fixed;inset:0;background:#3b82f626;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:5000;display:flex;align-items:center;justify-content:center;border:4px dashed var(--primary-color);margin:1rem;border-radius:12px;pointer-events:all;animation:fadeIn .2s ease-out}.drop-overlay-content{background:#1e1e1e;padding:3rem;border-radius:16px;text-align:center;box-shadow:0 20px 50px #00000080;display:flex;flex-direction:column;gap:1rem;border:1px solid #333;transform:translateY(0);transition:transform .2s}.drop-overlay h2{margin:0;color:#fff}.drop-overlay p{margin:0;color:#888}
