body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.filters-card{background:var(--color-bg-elevated);border:1px solid var(--color-border-light);border-radius:12px;box-shadow:var(--shadow-card);margin-bottom:16px;padding:12px 16px}.filters-row{display:flex;flex-direction:column;gap:12px}.filters-title{color:var(--color-text-tertiary);font-size:.75rem;font-weight:600;letter-spacing:.05em;margin-bottom:4px;text-transform:uppercase}.filters-chips{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.filters-chips::-webkit-scrollbar{height:4px}.filters-chips::-webkit-scrollbar-thumb{background:var(--color-border-medium);border-radius:999px}.filters-chips::-webkit-scrollbar-track{background:#0000}.filter-chip{align-items:center;background:var(--color-bg-secondary);border:1.5px solid var(--color-border-light);border-radius:10px;color:var(--color-text-secondary);cursor:pointer;display:flex;font-size:.85rem;font-weight:500;gap:6px;justify-content:center;min-height:36px;padding:8px 12px;transition:all .15s ease;white-space:nowrap}.filter-chip:hover{background:var(--color-bg-elevated);border-color:var(--color-primary);box-shadow:0 2px 4px #0000000d;color:var(--color-primary);transform:translateY(-1px)}.filter-chip.on{background:var(--color-primary);border-color:var(--color-primary);box-shadow:0 2px 8px #f59e0b4d;color:#fff;font-weight:600}.filter-chip.on:hover{background:var(--color-primary-dark);transform:translateY(-1px)}.chip-emoji{font-size:1rem;line-height:1}.chip-label{font-size:.85rem}.filters-sort-row{align-items:center;border-top:1px solid var(--color-border-light);display:flex;justify-content:flex-end;margin-top:12px;padding-top:12px}.filters-sort-label{align-items:center;color:var(--color-text-secondary);display:inline-flex;font-size:.75rem;gap:6px}.filters-sort-label select{-webkit-appearance:none;appearance:none;background:var(--color-bg-elevated);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;background-size:16px;border:1.5px solid var(--color-border-medium);border-radius:8px;color:var(--color-text-primary);cursor:pointer;font-size:.85rem;font-weight:500;outline:none;padding:6px 32px 6px 12px;transition:all .15s ease}.filters-sort-label select:hover{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23f59e0b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");border-color:var(--color-primary)}.filters-sort-label select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #f59e0b1a}@media (max-width:480px){.filters-chips{-webkit-overflow-scrolling:touch;display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;scroll-snap-type:x mandatory}.filter-chip{flex:0 0 auto;scroll-snap-align:start}.filters-chips::-webkit-scrollbar{height:4px}.filters-chips::-webkit-scrollbar-track{background:var(--color-bg-secondary);border-radius:2px}.filters-chips::-webkit-scrollbar-thumb{background:var(--color-border-medium);border-radius:2px}}*{box-sizing:border-box}:root{--color-primary:#f59e0b;--color-primary-dark:#d97706;--color-primary-light:#fbbf24;--color-primary-soft:#fff7ed;--color-bg-main:#fff;--color-bg-secondary:#f9fafb;--color-bg-tertiary:#f3f4f6;--color-bg-elevated:#fff;--color-bg-page:#f7f4ef;--color-text-primary:#111827;--color-text-secondary:#6b7280;--color-text-tertiary:#9ca3af;--color-border-light:#e5e7eb;--color-border-medium:#d1d5db;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a;--shadow-card:0 2px 8px #00000014;--color-bg:#f7f4ef;--color-text-main:#111827}@media (prefers-color-scheme:dark){:root{--color-primary:#fbbf24;--color-primary-dark:#f59e0b;--color-primary-light:#fcd34d;--color-primary-soft:#422006;--color-bg-main:#111827;--color-bg-secondary:#1f2937;--color-bg-tertiary:#374151;--color-bg-elevated:#1f2937;--color-bg-page:#0f172a;--color-text-primary:#f9fafb;--color-text-secondary:#d1d5db;--color-text-tertiary:#9ca3af;--color-border-light:#374151;--color-border-medium:#4b5563;--shadow-sm:0 1px 2px 0 #0006;--shadow-md:0 4px 6px -1px #00000080;--shadow-lg:0 10px 15px -3px #0009;--shadow-card:0 2px 12px #00000080;--color-bg:#0f172a;--color-text-main:#f9fafb}}#root,body,html{background:#f7f4ef;background:var(--color-bg);color:#111827;color:var(--color-text-main);font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;height:100%;margin:0;padding:0}.app{background:#f9fafb;background:var(--color-bg-secondary);display:flex;flex-direction:column;margin:0 auto;max-width:600px;min-height:100vh}.app-header{background:#fff;background:var(--color-bg-elevated);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--color-border-light);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);padding:16px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header-content{align-items:center;display:flex;gap:16px;justify-content:space-between}.app-title{font-size:1.4rem;margin:0}.app-title a{color:inherit;text-decoration:none}.header-nav{align-items:center;display:flex;gap:12px}.nav-link{color:#f59e0b;color:var(--color-primary);font-size:.9rem;font-weight:500;text-decoration:none}.nav-link:hover{text-decoration:underline}.user-menu{align-items:center;display:flex;gap:8px}.user-name{font-size:.85rem}.btn-logout,.user-name{color:#6b7280;color:var(--color-text-secondary)}.btn-logout{background:#f3f4f6;background:var(--color-bg-tertiary);border:1px solid #e5e7eb;border:1px solid var(--color-border-light);border-radius:999px;cursor:pointer;font-size:.8rem;padding:4px 12px;transition:all .15s ease}.btn-logout:hover{background:#f9fafb;background:var(--color-bg-secondary);border-color:#f59e0b;border-color:var(--color-primary);transform:translateY(-1px)}.btn-login{background:#f59e0b;background:var(--color-primary);border:1px solid #f59e0b;border:1px solid var(--color-primary);border-radius:999px;color:#fff;cursor:pointer;font-size:.85rem;padding:6px 16px;text-decoration:none}.btn-login:hover{background:#d97706;background:var(--color-primary-dark)}.app-main{flex:1 1;overflow-y:auto}.page-container{padding:16px}.btn-primary,.btn-secondary{border:1px solid #0000;border-radius:12px;cursor:pointer;font-size:.95rem;font-weight:500;padding:10px 18px;transition:all .15s ease}.btn-primary{background:#f59e0b;background:var(--color-primary);color:#fff}.btn-primary:hover{background:#d97706;background:var(--color-primary-dark);box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-primary:disabled{cursor:not-allowed;opacity:.5}.btn-secondary{background:#f3f4f6;background:var(--color-bg-tertiary);border-color:#e5e7eb;border-color:var(--color-border-light);color:#111827;color:var(--color-text-primary)}.btn-secondary:hover{background:#f9fafb;background:var(--color-bg-secondary);border-color:#f59e0b;border-color:var(--color-primary);transform:translateY(-1px)}.bars-list{display:flex;flex-direction:column;gap:16px}.bar-card{background:#fff;background:var(--color-bg-elevated);border:1px solid #e5e7eb;border:1px solid var(--color-border-light);border-radius:16px;box-shadow:0 2px 8px #00000014;box-shadow:var(--shadow-card);overflow:hidden;padding:16px;position:relative;transition:all .2s ease}.bar-card:before{background:linear-gradient(90deg,#f59e0b,#fbbf24);background:linear-gradient(90deg,var(--color-primary),var(--color-primary-light));content:"";height:3px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transition:transform .2s ease}.bar-card:hover:before{transform:scaleX(1)}.bar-card:hover{border-color:#f59e0b;border-color:var(--color-primary);box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.bar-card-header{align-items:flex-start;display:flex;gap:12px;justify-content:space-between;margin-bottom:8px}.bar-card-title h3{color:#111827;color:var(--color-text-primary);font-size:1.1rem;font-weight:700;letter-spacing:-.01em;margin:0}.bar-name-link{color:inherit;display:block;text-decoration:none;transition:color .2s}.bar-name-link:hover{color:#f59e0b;color:var(--color-primary)}.bar-name-link h3{margin:0}.music-style-badge{background:#f3f4f6;background:var(--color-bg-tertiary);border-radius:999px;color:#9ca3af;color:var(--color-text-tertiary);font-size:.75rem;font-weight:500;margin-left:8px;padding:2px 8px;white-space:nowrap}.bar-neighborhood{color:#6b7280;color:var(--color-text-secondary);display:block;font-size:.85rem;margin-top:4px}.bar-neighborhood:before{content:"📍";font-size:.8rem;margin-right:4px}.bar-notes{word-wrap:break-word;color:#6b7280;color:var(--color-text-secondary);font-size:.9rem;line-height:1.5;margin:8px 0;overflow-wrap:break-word}.bar-card-footer{border-top:1px solid #f0f0f0;justify-content:space-between;margin-top:12px;padding-top:12px}.bar-card-actions,.bar-card-footer{align-items:center;display:flex;gap:12px}.bar-card-actions{flex-shrink:0}.bar-comment-button{align-items:center;background:#f3f4f6;background:var(--color-bg-tertiary);border:1px solid #e5e7eb;border:1px solid var(--color-border-light);border-radius:20px;color:#6b7280;color:var(--color-text-secondary);cursor:pointer;display:flex;flex-shrink:0;gap:6px;padding:6px 12px;text-decoration:none;transition:all .15s ease}.bar-comment-button:hover{background:#fff;background:var(--color-bg-elevated);border-color:#f59e0b;border-color:var(--color-primary);box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-1px)}.bar-comment-button .comment-icon{font-size:1.3rem;line-height:1}.bar-comment-button .comment-count{color:#111827;color:var(--color-text-primary);font-size:.9rem;font-weight:600}.bar-author{color:#9ca3af;color:var(--color-text-tertiary);flex-shrink:1;font-size:.75rem;max-width:150px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bar-meta{align-items:center;display:flex;justify-content:space-between;margin-top:12px}.btn-edit{background:#0000;border:1px solid #e5e7eb;border:1px solid var(--color-border-light);border-radius:8px;color:#6b7280;color:var(--color-text-secondary);cursor:pointer;font-size:.85rem;padding:6px 12px;transition:all .15s ease}.btn-edit:hover{background:#f9fafb;background:var(--color-bg-secondary);border-color:#f59e0b;border-color:var(--color-primary);color:#f59e0b;color:var(--color-primary);transform:translateY(-1px)}.upvote-btn{align-items:center;background:#f3f4f6;background:var(--color-bg-tertiary);border:1px solid #e5e7eb;border:1px solid var(--color-border-light);border-radius:20px;color:#6b7280;color:var(--color-text-secondary);cursor:pointer;display:flex;flex-shrink:0;font-size:.85rem;font-weight:600;gap:6px;padding:6px 12px;transition:all .15s ease;white-space:nowrap}.upvote-btn:hover:not(.disabled){background:#fff;background:var(--color-bg-elevated);box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-1px)}.upvote-btn.active,.upvote-btn:hover:not(.disabled){border-color:#f59e0b;border-color:var(--color-primary)}.upvote-btn.active{background:#f59e0b;background:var(--color-primary);color:#fff}.upvote-btn.active:hover{background:#d97706;background:var(--color-primary-dark)}.upvote-btn.active .upvote-arrow{color:#f59e0b;color:var(--color-primary)}.upvote-btn.disabled{cursor:not-allowed;opacity:.4}.upvote-arrow{font-size:1.2rem;line-height:1;transition:color .2s}.feature-pills{display:flex;flex-wrap:wrap;gap:6px;margin:8px 0}.feature-pill{align-items:center;background:#f3f4f6;background:var(--color-bg-tertiary);border:1px solid #e5e7eb;border:1px solid var(--color-border-light);border-radius:999px;color:#6b7280;color:var(--color-text-secondary);display:inline-flex;font-size:.75rem;gap:4px;padding:4px 10px;transition:all .15s ease}.feature-toggles{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0}.feature-toggle{align-items:center;background:#fff;background:var(--color-bg-elevated);border:2px solid #e5e7eb;border:2px solid var(--color-border-light);border-radius:999px;color:#6b7280;color:var(--color-text-secondary);cursor:pointer;display:flex;font-size:.8rem;gap:6px;padding:6px 12px;transition:all .15s ease}.feature-toggle:hover{background:#f3f4f6;background:var(--color-bg-tertiary);border-color:#f59e0b;border-color:var(--color-primary)}.feature-toggle:has(input:checked){background:#f59e0b;background:var(--color-primary);border-color:#f59e0b;border-color:var(--color-primary);color:#fff}.feature-toggle:has(input:checked):hover{background:#d97706;background:var(--color-primary-dark)}.feature-toggle input[type=checkbox]{cursor:pointer;margin:0}.feature-toggle-label{cursor:pointer}.form-group{margin-bottom:16px}.form-group label{color:#111827;color:var(--color-text-primary);display:block;font-size:.9rem;font-weight:500;margin-bottom:6px}.form-group input,.form-group textarea{background:#fff;background:var(--color-bg-elevated);border:1px solid #e5e7eb;border:1px solid var(--color-border-light);border-radius:10px;color:#111827;color:var(--color-text-primary);font-family:inherit;font-size:.95rem;outline:none;padding:10px 12px;transition:all .15s ease;width:100%}.form-group input:focus,.form-group textarea:focus{border-color:#f59e0b;border-color:var(--color-primary);box-shadow:0 0 0 3px #f59e0b1a}.music-styles-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.music-style-chip{background:#fff;background:var(--color-bg-elevated);border:2px solid #e5e7eb;border:2px solid var(--color-border-light);border-radius:8px;color:#6b7280;color:var(--color-text-secondary);cursor:pointer;font-size:.85rem;font-weight:500;padding:8px 12px;text-align:center;transition:all .15s ease}.music-style-chip:hover{background:#f3f4f6;background:var(--color-bg-tertiary);transform:translateY(-1px)}.music-style-chip.selected,.music-style-chip:hover{border-color:#f59e0b;border-color:var(--color-primary)}.music-style-chip.selected{background:#f59e0b;background:var(--color-primary);color:#fff}.music-style-chip.selected:hover{background:#d97706;background:var(--color-primary-dark)}.form-actions{display:flex;gap:12px;margin-top:20px}.form-actions button{flex:1 1}.suggest-form-container{background:#fff;background:var(--color-bg-elevated);border:1px solid #e5e7eb;border:1px solid var(--color-border-light);border-radius:16px;box-shadow:0 2px 8px #00000014;box-shadow:var(--shadow-card);padding:20px}.suggest-form-container h2{color:#111827;color:var(--color-text-primary);font-size:1.3rem;margin:0 0 20px}.suggest-login-prompt{background:#fff;background:var(--color-bg-elevated);border:1px solid #e5e7eb;border:1px solid var(--color-border-light);border-radius:16px;box-shadow:0 2px 8px #00000014;box-shadow:var(--shadow-card);padding:40px 20px;text-align:center}.suggest-login-prompt h2{color:#111827;color:var(--color-text-primary);margin:0 0 12px}.suggest-login-prompt p{color:#6b7280;color:var(--color-text-secondary);margin:0 0 20px}.bar-detail{background:#fff;background:var(--color-bg-elevated);border:1px solid #e5e7eb;border:1px solid var(--color-border-light);border-radius:16px;box-shadow:0 2px 8px #00000014;box-shadow:var(--shadow-card);overflow-x:hidden;padding:20px}.bar-detail-header{margin-bottom:12px}.bar-detail h1{color:#111827;color:var(--color-text-primary);font-size:1.5rem;font-weight:700;letter-spacing:-.01em;margin:0}.bar-detail hr{border:none;border-top:1px solid #e5e7eb;border-top:1px solid var(--color-border-light);margin:20px 0}.bar-detail-footer{border-top:1px solid #f0f0f0;justify-content:space-between;margin-top:12px;padding-top:12px}.bar-detail-actions,.bar-detail-footer{align-items:center;display:flex;gap:12px}.bar-detail-actions{flex-shrink:0}.contributors-section{border-top:1px solid #e5e7eb;border-top:1px solid var(--color-border-light);margin-top:24px;padding-top:20px}.contributors-section h3{color:#6b7280;color:var(--color-text-secondary);font-size:.9rem;font-weight:600;letter-spacing:.5px;margin:0 0 8px;text-transform:uppercase}.contributors-list{color:#9ca3af;color:var(--color-text-tertiary);font-size:.85rem;margin:0}.contributor-name{color:#f59e0b;color:var(--color-primary);font-weight:500}.comments-section{overflow-x:hidden}.comments-section h2{color:#111827;color:var(--color-text-primary);font-size:1.2rem;margin:0 0 16px}.comments-empty{background:#f9fafb;background:var(--color-bg-secondary);border:1px solid #e5e7eb;border:1px solid var(--color-border-light);border-radius:10px;color:#9ca3af;color:var(--color-text-tertiary);font-size:.9rem;padding:20px;text-align:center}.comments-list{list-style:none;margin:0 0 16px;padding:0}.comments-list.replies{margin-left:24px;margin-top:8px}.comment-item{margin-bottom:12px}.comment-bubble{word-wrap:break-word;background:#f9fafb;background:var(--color-bg-secondary);border:1px solid #e5e7eb;border:1px solid var(--color-border-light);border-radius:12px;overflow-wrap:break-word;padding:10px 12px}.comment-bubble.reply{background:#fff7ed;background:var(--color-primary-soft)}.comment-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px}.comment-author{color:#111827;color:var(--color-text-primary);font-size:.85rem;font-weight:600}.comment-reply-btn{background:#0000;border:none;border-radius:4px;color:#f59e0b;color:var(--color-primary);cursor:pointer;font-size:.8rem;padding:2px 8px}.comment-reply-btn:hover{background:#f59e0b1f}.comment-text{word-wrap:break-word;color:#6b7280;color:var(--color-text-secondary);font-size:.9rem;line-height:1.4;margin:0;overflow-wrap:break-word;word-break:break-word}.new-comment-form,.reply-form{margin-top:16px}.reply-form{background:#f9fafb;background:var(--color-bg-secondary);border:1px solid #e5e7eb;border:1px solid var(--color-border-light);border-radius:10px;margin-bottom:16px;padding:12px}.reply-form-header{align-items:center;color:#6b7280;color:var(--color-text-secondary);display:flex;font-size:.85rem;justify-content:space-between;margin-bottom:8px}.reply-form-header button{background:none;border:none;color:#9ca3af;color:var(--color-text-tertiary);cursor:pointer;font-size:.85rem;transition:all .15s ease}.reply-form-header button:hover{color:#f59e0b;color:var(--color-primary)}.new-comment-form textarea,.reply-form textarea{background:#fff;background:var(--color-bg-elevated);border:1px solid #e5e7eb;border:1px solid var(--color-border-light);border-radius:10px;color:#111827;color:var(--color-text-primary);font-family:inherit;font-size:.9rem;margin-bottom:8px;padding:10px 12px;resize:vertical;transition:all .15s ease;width:100%}.new-comment-form textarea:focus,.reply-form textarea:focus{border-color:#f59e0b;border-color:var(--color-primary);box-shadow:0 0 0 3px #f59e0b1a;outline:none}.new-comment-form button,.reply-form button[type=submit]{background:#f59e0b;background:var(--color-primary);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem;padding:8px 16px;transition:all .15s ease}.new-comment-form button:hover:not(:disabled),.reply-form button[type=submit]:hover:not(:disabled){background:#d97706;background:var(--color-primary-dark);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);transform:translateY(-1px)}.new-comment-form button:disabled,.reply-form button:disabled{cursor:not-allowed;opacity:.5}.login-prompt{background:#f9fafb;background:var(--color-bg-secondary);border:1px solid #e5e7eb;border:1px solid var(--color-border-light);border-radius:10px;margin-top:16px;padding:20px;text-align:center}.login-prompt p{color:#6b7280;color:var(--color-text-secondary);margin:0 0 12px}.login-prompt button{background:#f59e0b;background:var(--color-primary);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem;padding:8px 20px}.login-page{align-items:center;display:flex;justify-content:center;min-height:calc(100vh - 60px);padding:20px}.empty-message{color:#9ca3af;color:var(--color-text-tertiary);font-size:.95rem;padding:40px 20px;text-align:center}.error-message{background:#ef53501a;border:1px solid #ef5350;border-radius:10px;color:#ef5350;font-size:.9rem;margin:12px 0;padding:12px 16px}@media (prefers-color-scheme:dark){.error-message{background:#ef535026;border-color:#f87171;color:#fca5a5}}.error-message button{background:#ef5350;border:none;border-radius:8px;color:#fff;cursor:pointer;margin-top:8px;padding:6px 14px;transition:all .15s ease}.error-message button:hover{background:#c62828}@media (max-width:600px){.app-header{padding:10px 12px}.header-content{flex-wrap:nowrap;gap:8px}.app-title{flex-shrink:1;font-size:1rem;min-width:0}.app-title a{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-nav{flex-shrink:0;gap:6px}.nav-link{font-size:.75rem;padding:4px 8px}.user-menu{gap:6px}.user-name{font-size:.75rem;max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-logout{font-size:.75rem;padding:4px 10px}.bar-card-header{align-items:stretch;flex-direction:column}}@media (max-width:480px){.bar-card-footer,.bar-detail-footer{flex-wrap:wrap}.bar-author{flex-basis:100%;margin-top:8px;text-align:center}}
/*# sourceMappingURL=main.132933f2.css.map*/