:root{--bg-color:#fff;--bg-secondary:#fafafa;--text-primary:#111827;--text-secondary:#6b7280;--border-color:#f3f4f6;--border-hover:#e5e7eb;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--spacing-sm:.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--shadow-up:0 -4px 6px -1px #0000001a;--radius-md:.75rem;--radius-lg:1rem;--radius-xl:1.5rem;--accent-color:#000;--accent-text:#fff}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--bg-color);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5;overflow:hidden}#root{flex-direction:column;width:100vw;height:100vh;display:flex}.app-container{flex-direction:column;width:100%;height:100%;display:flex;position:relative}.map-container{z-index:1;flex:1;width:100%;height:100%;position:absolute;top:0;left:0}.sheet-container{background-color:var(--bg-color);border-top-left-radius:var(--radius-xl);border-top-right-radius:var(--radius-xl);width:100%;height:80vh;box-shadow:var(--shadow-up);z-index:10;will-change:transform;flex-direction:column;display:flex;position:absolute;bottom:0;left:0}.sheet-header{padding:var(--spacing-md);cursor:grab;border-bottom:1px solid var(--border-color);justify-content:center;align-items:center;display:flex}.sheet-header:active{cursor:grabbing}.drag-handle{background-color:var(--border-hover);border-radius:9999px;width:40px;height:5px}.sheet-content{padding:var(--spacing-sm) var(--spacing-lg) calc(var(--spacing-lg) * 3);flex:1;overflow-y:auto}@media (width>=768px){#root,.app-container{flex-direction:row}.sheet-container{border-right:1px solid var(--border-color);width:400px;height:100vh;box-shadow:var(--shadow-md);z-index:10;border-radius:0;position:relative;transform:none!important}.sheet-header{display:none}.map-container{flex:1;position:relative}}.place-card{background-color:var(--bg-color);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-md);cursor:pointer;transition:all .2s ease-in-out}.place-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-md);transform:translateY(-2px)}.place-card-header{margin-bottom:var(--spacing-sm);justify-content:space-between;align-items:flex-start;display:flex}.place-title{color:var(--text-primary);margin-right:var(--spacing-sm);font-size:1.125rem;font-weight:600}.place-type{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);background-color:var(--bg-secondary);white-space:nowrap;border-radius:9999px;padding:.25rem .5rem;font-size:.75rem;font-weight:500}.place-district{color:var(--text-secondary);margin-bottom:var(--spacing-sm);flex-wrap:wrap;align-items:center;gap:.25rem;font-size:.875rem;display:flex}.place-notes{color:var(--text-primary);font-size:.9375rem;line-height:1.5}.day-header{margin-top:var(--spacing-xl);margin-bottom:var(--spacing-md);color:var(--text-primary);border-bottom:1px solid var(--border-color);padding-bottom:var(--spacing-sm);font-size:1.25rem;font-weight:700}.day-header:first-of-type{margin-top:0}.loading-container{width:100vw;height:100vh;color:var(--text-secondary);justify-content:center;align-items:center;font-size:1.25rem;display:flex}.day-filters{top:var(--spacing-md);z-index:20;gap:var(--spacing-sm);background-color:var(--bg-color);box-shadow:var(--shadow-md);border:1px solid var(--border-color);border-radius:9999px;padding:.5rem;display:flex;position:absolute;left:50%;transform:translate(-50%)}.day-tab{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:9999px;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s ease-in-out}.day-tab:hover{background-color:var(--bg-secondary);color:var(--text-primary)}.day-tab.active{background-color:var(--accent-color);color:var(--accent-text)}.check-btn{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;justify-content:center;align-items:center;transition:all .2s;display:flex}.check-btn:hover{color:var(--text-primary)}.place-card.completed{opacity:.6;background-color:var(--bg-secondary)}.place-card.completed .place-title{color:var(--text-secondary);text-decoration:line-through}.text-gray-400{color:#9ca3af}.nearby-panel{top:6rem;right:var(--spacing-md);background-color:var(--bg-color);border-radius:var(--radius-md);width:250px;box-shadow:var(--shadow-lg);border:1px solid var(--border-color);z-index:20;padding:var(--spacing-sm);position:absolute}@media (width<=767px){.nearby-panel{width:90%;top:auto;bottom:calc(80vh + 1rem);right:50%;transform:translate(50%)}}.nearby-title{text-transform:uppercase;color:var(--text-secondary);margin-bottom:var(--spacing-sm);padding:0 var(--spacing-sm);font-size:.75rem;font-weight:700}.nearby-list{flex-direction:column;gap:.25rem;display:flex}.nearby-item{padding:var(--spacing-sm);border-radius:var(--radius-md);cursor:pointer;transition:background-color .2s}.nearby-item:hover{background-color:var(--bg-secondary)}.nearby-item-header{justify-content:space-between;align-items:center;margin-bottom:.25rem;display:flex}.nearby-item-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;max-width:70%;font-size:.875rem;font-weight:600;overflow:hidden}.nearby-item-dist{color:#3b82f6;background-color:#eff6ff;border-radius:9999px;padding:.125rem .375rem;font-size:.75rem;font-weight:600}.nearby-item-district{color:var(--text-secondary);align-items:center;gap:.25rem;font-size:.75rem;display:flex}.ml-auto{margin-left:auto}.place-card-content-wrapper{gap:var(--spacing-md);align-items:flex-start;display:flex}.place-photo-container{border-radius:var(--radius-md);background-color:var(--bg-secondary);flex-shrink:0;width:80px;height:80px;overflow:hidden}.place-photo{object-fit:cover;width:100%;height:100%}.place-info{flex:1;min-width:0}.place-actions{margin-top:var(--spacing-sm);justify-content:flex-end;display:flex}.open-maps-link{color:#3b82f6;border-radius:var(--radius-md);background-color:#eff6ff;align-items:center;gap:.25rem;padding:.25rem .5rem;font-size:.75rem;font-weight:600;text-decoration:none;transition:background-color .2s;display:inline-flex}.open-maps-link:hover{background-color:#dbeafe}.info-window-content{max-width:200px;padding:.25rem}
