.photo-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.photo-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00ff8726}.photo-preview{position:relative;width:100%;aspect-ratio:3/2;background:var(--background);overflow:hidden}.photo-preview img{width:100%;height:100%;object-fit:cover}.photo-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.loading-spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.photo-overlay{position:absolute;top:0;left:0;right:0;padding:.75rem;display:flex;justify-content:space-between;opacity:0;transition:opacity .2s ease;background:linear-gradient(to bottom,rgba(0,0,0,.6),transparent)}.photo-card:hover .photo-overlay{opacity:1}.time-badge{background:#00ff87e6;color:#000;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600}.photo-info{padding:1rem}.photo-filename{font-size:.9rem;font-weight:500;color:var(--text);margin-bottom:.75rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.photo-meta{display:flex;gap:1rem;margin-bottom:1rem}.meta-item{display:flex;align-items:center;gap:.375rem;font-size:.8rem;color:var(--text-secondary)}.meta-item svg{color:var(--primary)}.photo-actions{display:flex;gap:.5rem}.action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem;border-radius:8px;font-size:.875rem;font-weight:500;transition:all .2s ease}.action-btn.download{background:var(--primary);color:#000}.action-btn.download:hover{background:#00cc6f;transform:translateY(-2px)}.action-btn.copy,.action-btn.delete{background:var(--background);color:var(--text);border:1px solid var(--border)}.action-btn.copy:hover{background:#00ff871a;border-color:var(--primary);color:var(--primary)}.action-btn.delete:hover{background:#ff38601a;border-color:var(--danger);color:var(--danger)}.action-btn span{display:none}.action-btn.download span{display:inline}@media (min-width: 768px){.action-btn span{display:inline}}@media (max-width: 480px){.photo-actions{flex-direction:column}.action-btn{width:100%}.action-btn span{display:inline}}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;padding:1rem 0}@media (max-width: 768px){.photo-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}}@media (max-width: 480px){.photo-grid{grid-template-columns:1fr}}.header{background:var(--surface);border-bottom:1px solid var(--border);padding:1.5rem 2rem;position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.header-content{max-width:1800px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.header-left{display:flex;align-items:center;gap:1rem}.header-icon{color:var(--primary)}.header-title{font-size:1.5rem;font-weight:700;color:var(--text);margin:0}.header-subtitle{font-size:.875rem;color:var(--text-secondary);margin:0}.header-stats{display:flex;gap:2rem}.stat{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.9rem}.stat svg{color:var(--primary)}@media (max-width: 768px){.header{padding:1rem}.header-content{flex-direction:column;gap:1rem}.header-stats{gap:1rem}.header-title{font-size:1.25rem}}.connection-status{position:fixed;top:1rem;right:1rem;display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:500;z-index:1000;transition:all .3s ease}.connection-status.connected{background:#00ff871a;color:var(--primary);border:1px solid rgba(0,255,135,.3)}.connection-status.disconnected{background:#ff38601a;color:var(--danger);border:1px solid rgba(255,56,96,.3);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@media (max-width: 768px){.connection-status{top:auto;bottom:1rem;right:1rem}}.app{min-height:100vh;background:var(--background)}.main-content{padding:2rem;max-width:1800px;margin:0 auto}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;padding:2rem}.empty-icon{font-size:5rem;margin-bottom:1rem;opacity:.5}.empty-state h2{font-size:2rem;margin-bottom:.5rem;color:var(--text)}.empty-state p{font-size:1.1rem;color:var(--text-secondary);margin-bottom:2rem}.setup-instructions{width:100%;max-width:800px;text-align:left;display:flex;flex-direction:column;gap:1.5rem}.setup-instructions h3{color:var(--primary);font-size:1.1rem;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}.ftp-connection{background:var(--surface);padding:1.5rem;border-radius:12px;border:1px solid var(--primary)}.connection-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem}.connection-item{display:flex;flex-direction:column;gap:.25rem}.connection-item .label{font-size:.75rem;text-transform:uppercase;color:var(--text-secondary);font-weight:600}.connection-item code{background:var(--background);padding:.5rem .75rem;border-radius:6px;font-family:SF Mono,Monaco,Courier New,monospace;font-size:.9rem;color:var(--primary)}.camera-steps,.transfer-steps,.crop-tip{background:var(--surface);padding:1.5rem;border-radius:12px;border:1px solid var(--border)}.camera-steps ol,.transfer-steps ol{margin:0;padding-left:1.5rem}.camera-steps li,.transfer-steps li{margin-bottom:.75rem;color:var(--text)}.camera-steps li:last-child,.transfer-steps li:last-child{margin-bottom:0}.camera-steps li strong,.transfer-steps li strong{color:var(--text)}.camera-steps li p,.transfer-steps li p{margin:.25rem 0 0;font-size:.9rem;color:var(--text-secondary)}.pro-tip{margin-top:1rem;padding:1rem;background:#4ade801a;border-radius:8px;border-left:3px solid var(--primary);font-size:.9rem}.pro-tip p{margin:.5rem 0 0;color:var(--text-secondary)}.crop-tip p{margin:.5rem 0;color:var(--text-secondary);font-size:.9rem}.crop-tip p:first-of-type{margin-top:0}@media (max-width: 768px){.main-content{padding:1rem}.empty-state{min-height:auto;padding:1rem}.empty-state h2{font-size:1.5rem}.empty-state>p{font-size:1rem;margin-bottom:1.5rem}.setup-instructions{gap:1rem}.ftp-connection,.camera-steps,.transfer-steps,.crop-tip{padding:1rem}.connection-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.setup-instructions h3{font-size:1rem}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#0a0a0a;color:#fff}:root{--primary: #00ff87;--danger: #ff3860;--background: #0a0a0a;--surface: #1a1a1a;--border: #2a2a2a;--text: #ffffff;--text-secondary: #a0a0a0}button{cursor:pointer;border:none;background:none;font-family:inherit}img{max-width:100%;height:auto;display:block}
