.app{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.header h1{margin:0;font-size:1.5rem;font-weight:700}.tab-button{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:.25rem;font-size:.75rem}@media (min-width: 768px){.tab-button{flex-direction:row;font-size:.875rem}}.photo-upload:hover{border-color:#667eea;background-color:#667eea0d}.restaurant-item:hover{background-color:#f8f9fa}.loading{display:flex;align-items:center;justify-content:center;padding:2rem;color:#666}@media (max-width: 768px){.header h1{font-size:1.25rem}.tab-content{padding:.75rem}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}.header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1rem 2rem;box-shadow:0 2px 10px #0000001a}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto}.header-right{display:flex;align-items:center;gap:1rem}.connection-status{display:flex;align-items:center;gap:.5rem;font-size:.9rem;opacity:.9}.user-info{display:flex;align-items:center;gap:.5rem;background:#ffffff1a;padding:.5rem 1rem;border-radius:8px;border:1px solid rgba(255,255,255,.2)}.user-details{display:flex;align-items:center;gap:.5rem;font-size:.9rem}.npub{font-family:monospace;font-size:.8rem;opacity:.8}.logout-btn{background:none;border:none;color:#fff;cursor:pointer;padding:.25rem;border-radius:4px;transition:background-color .2s}.logout-btn:hover{background:#ffffff1a}.login-btn{display:flex;align-items:center;gap:.5rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-size:.9rem;transition:all .2s}.login-btn:hover{background:#fff3;border-color:#ffffff80}@media (max-width: 768px){.header-content{flex-direction:column;gap:1rem;text-align:center}.header-right{flex-direction:column;gap:.5rem}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}#root{width:100%;height:100vh;margin:0 auto;text-align:center}.app{width:100%;height:100vh;display:flex;flex-direction:column}.header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1rem;box-shadow:0 2px 10px #0000001a}.main-content{flex:1;display:flex;overflow:hidden}.sidebar{width:300px;background:#f8f9fa;border-right:1px solid #dee2e6;overflow-y:auto;color:#333}.map-container{flex:1;position:relative}.leaflet-container{height:100%;width:100%}.tab-buttons{display:flex;background:#e9ecef;border-bottom:1px solid #dee2e6}.tab-button{flex:1;padding:.75rem;border:none;background:transparent;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s}.tab-button.active{background:#fff;border-bottom-color:#667eea;color:#667eea}.tab-content{padding:1rem}.location-item{display:flex;align-items:center;padding:.75rem;border-bottom:1px solid #e9ecef;gap:.5rem}.location-item:last-child{border-bottom:none}.status-indicator{width:8px;height:8px;border-radius:50%;background:#28a745}.photo-upload{border:2px dashed #dee2e6;border-radius:8px;padding:2rem;text-align:center;cursor:pointer;transition:border-color .2s}.photo-upload:hover{border-color:#667eea}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem;margin-top:1rem}.photo-item{position:relative;border-radius:8px;overflow:hidden;aspect-ratio:1}.photo-item img{width:100%;height:100%;object-fit:cover}.restaurant-item{padding:1rem;border-bottom:1px solid #e9ecef}.restaurant-item:last-child{border-bottom:none}.restaurant-name{font-weight:600;margin-bottom:.25rem}.restaurant-type{color:#6c757d;font-size:.875rem;margin-bottom:.5rem}.restaurant-rating{display:flex;align-items:center;gap:.25rem;color:#ffc107}.connection-status{display:flex;align-items:center;gap:.5rem;font-size:.875rem;margin-top:.5rem}.connection-indicator{width:8px;height:8px;border-radius:50%;background:#dc3545}.connection-indicator.connected{background:#28a745}@media (max-width: 768px){.main-content{flex-direction:column}.sidebar{width:100%;height:40vh}.map-container{height:60vh}}
