@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&family=Inter:wght@400;500;600&display=swap";:root{--bg: #ebe8e0;--bg-elev: #f6f3ec;--ink: #0a0a0a;--ink-dim: #6a6a6a;--ink-soft: #8a8a8a;--line: #cfccc2;--accent: #d94f3c;--radius: 4px;--font-display: "Space Grotesk", "Helvetica Neue", Arial, sans-serif;--font-body: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--text: var(--ink);--text-dim: var(--ink-dim);--border: var(--line);--danger: var(--accent)}#discWrap{--text: var(--ink);--text-dim: var(--ink-dim);--border: var(--line)}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:var(--font-body);min-height:100vh}h1,h2,h3{font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;margin:0 0 .5em}h1{font-size:2.75rem;line-height:1}h2{font-size:1.75rem}a{color:var(--ink);text-decoration:none}a:hover{color:var(--accent)}#nav{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;border-bottom:1px solid var(--line);background:var(--bg);height:60px}#nav .brand{font-family:var(--font-display);font-weight:700;font-size:1.1rem;letter-spacing:.15em;color:var(--ink);text-transform:uppercase}#nav .links a{margin-left:1.75rem;color:var(--ink);font-family:var(--font-display);font-size:.72rem;text-transform:uppercase;letter-spacing:.2em;font-weight:500}#nav .links a:hover{color:var(--accent)}#app{max-width:1120px;margin:0 auto;padding:2rem}input,textarea,button,select{font-family:inherit;font-size:1rem}input,textarea,select{width:100%;background:var(--bg-elev);border:1px solid var(--line);color:var(--ink);padding:.75rem 1rem;border-radius:var(--radius);margin-bottom:1rem}input:focus,textarea:focus{outline:none;border-color:var(--ink)}textarea{min-height:100px;resize:vertical}label{display:block;color:var(--ink-dim);font-family:var(--font-display);font-size:.7rem;text-transform:uppercase;letter-spacing:.2em;margin-bottom:.5rem}button{background:var(--ink);color:var(--bg);border:none;padding:.75rem 1.5rem;border-radius:var(--radius);cursor:pointer;font-family:var(--font-display);font-weight:500;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase}button:hover{background:var(--accent)}button.ghost{background:transparent;color:var(--ink);border:1px solid var(--ink)}button.ghost:hover{background:var(--ink);color:var(--bg)}.card{background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius);padding:1.25rem;margin-bottom:1rem}.card .meta{color:var(--ink-dim);font-family:var(--font-display);font-size:.7rem;text-transform:uppercase;letter-spacing:.15em;margin-bottom:.5rem}.card .song{font-family:var(--font-display);font-weight:600;font-size:1.05rem;margin-bottom:.25rem}.card .note{color:var(--ink-dim);font-style:italic;margin-top:.75rem}.toggle-row{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.toggle-row input{width:auto;margin:0}.error{color:var(--accent);font-size:.9rem;margin:.5rem 0}.empty{color:var(--ink-dim);text-align:center;padding:3rem 1rem}button.toggle{background:transparent;border:1px solid var(--line);color:var(--ink-dim);padding:.4rem 1rem;border-radius:999px;font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:all .2s}button.toggle:hover{color:var(--ink);border-color:var(--ink)}button.toggle.active{background:var(--ink);border-color:var(--ink);color:var(--bg)}.feed-page{--vinyl-size: min(80vh, 760px);--vinyl-off: calc(var(--vinyl-size) * .6);position:relative;width:100%}.feed-content{position:relative;z-index:1;padding-left:calc(var(--vinyl-size) - var(--vinyl-off) + 3rem);padding-right:2.5rem;padding-top:2rem;padding-bottom:2rem}.feed-header{display:flex;justify-content:space-between;align-items:flex-start;padding-bottom:1.5rem;border-bottom:1px solid var(--line);margin-bottom:2.5rem}.feed-header .mini{font-family:var(--font-display);font-size:.8rem;letter-spacing:.35em;text-transform:uppercase;font-weight:600}.feed-header .sub{font-family:var(--font-display);font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-dim);margin-top:.4rem}.feed-header .right{text-align:right}.vinyl-wrap{position:absolute;top:3rem;left:calc(-1 * var(--vinyl-off));width:var(--vinyl-size);height:var(--vinyl-size);z-index:0;pointer-events:none}.vinyl{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:repeating-radial-gradient(circle at 50% 50%,#0a0a0a,#0a0a0a 2px,#1d1d1d 2px,#1d1d1d 3px),#000;box-shadow:0 25px 60px #00000040,inset 0 0 40px #0009;animation:vinylSpin 6s linear infinite;animation-play-state:paused;transform-origin:50% 50%}.vinyl.playing{animation-play-state:running}@keyframes vinylSpin{to{transform:rotate(360deg)}}.vinyl.kick{animation:vinylSpin 6s linear infinite,kickSpin .9s cubic-bezier(.2,.8,.2,1)}@keyframes kickSpin{0%{transform:rotate(-35deg) scale(.94)}60%{transform:rotate(10deg) scale(1.02)}to{transform:rotate(0) scale(1)}}.vinyl .label{position:absolute;top:34%;right:34%;bottom:34%;left:34%;border-radius:50%;overflow:hidden;background:var(--bg-elev);display:flex;align-items:center;justify-content:center;box-shadow:0 0 0 2px #0a0a0a;animation:labelPop .4s ease}@keyframes labelPop{0%{opacity:.3;transform:scale(.85)}to{opacity:1;transform:scale(1)}}.vinyl .label img{width:100%;height:100%;object-fit:cover}.vinyl .label .label-text{font-family:var(--font-display);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-dim);font-weight:600}.vinyl .spindle{position:absolute;top:50%;left:50%;width:4%;height:4%;transform:translate(-50%,-50%);border-radius:50%;background:var(--bg);z-index:3;box-shadow:0 0 0 1px #222}.vinyl-ring{position:absolute;top:-14px;right:-14px;bottom:-14px;left:-14px;border-radius:50%;border:1px solid var(--accent);opacity:.55;pointer-events:none}.vinyl-time{position:absolute;top:calc(3rem + var(--vinyl-size) + .75rem);left:calc(var(--vinyl-size) - var(--vinyl-off) - 5rem);font-family:var(--font-display);font-size:.72rem;letter-spacing:.2em;color:var(--ink-dim);z-index:2}.focus-mini{font-family:var(--font-display);font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:.5rem}.focus-title{font-family:var(--font-display);font-weight:700;font-size:clamp(2.2rem,4.8vw,4rem);line-height:1;letter-spacing:-.03em;text-transform:uppercase;margin:0 0 .5rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.focus-sub{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.focus-sub{font-family:var(--font-display);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:2rem}.track-list-heading{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.2em;font-size:.78rem;color:var(--accent);margin-bottom:.75rem;font-weight:600}.track{display:grid;grid-template-columns:36px 64px 1fr auto;gap:1.1rem;align-items:center;padding:1.1rem .25rem;border-bottom:1px solid var(--line);cursor:pointer;transition:background .15s}.track:hover{background:#0000000a}.track.active .song{color:var(--accent)}.track .num{font-family:var(--font-display);color:var(--ink-dim);font-size:1rem;letter-spacing:.05em}.track .thumb{width:64px;height:64px;background:var(--bg-elev);border-radius:2px;object-fit:cover;display:block}.track .info{min-width:0}.track .info .song{font-family:var(--font-display);font-weight:700;font-size:1.65rem;line-height:1.05;text-transform:uppercase;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track .info .artist{color:var(--ink-dim);font-size:.82rem;margin-top:.25rem;letter-spacing:.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track .meta{color:var(--ink-dim);font-family:var(--font-display);font-size:.72rem;letter-spacing:.1em;text-align:right}.view-more{margin-top:1rem;font-family:var(--font-display);font-size:.72rem;letter-spacing:.25em;text-transform:uppercase;color:var(--ink-dim);text-align:right}.feed-footer{margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--line);text-align:center;font-family:var(--font-display);font-size:.75rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-dim)}.feed-footer .sub{font-size:.65rem;color:var(--ink-soft);margin-top:.3rem;letter-spacing:.25em}@media (max-width: 860px){.feed-page{--vinyl-size: 140vw;--vinyl-off: calc(var(--vinyl-size) * .65)}.feed-content{padding-left:1.5rem;padding-right:1.5rem;padding-top:calc(var(--vinyl-size) * .45)}.vinyl-wrap{top:0;transform:none}.vinyl-time{left:1.5rem;bottom:auto;top:calc(var(--vinyl-size) * .42)}.feed-header{flex-direction:column;gap:1rem}.feed-header .right{text-align:left}}.plus1{background:transparent;border:1px solid var(--line);color:var(--ink-dim);padding:.35rem .6rem;border-radius:999px;font-family:var(--font-display);font-size:.72rem;letter-spacing:.1em;display:inline-flex;align-items:center;gap:.4rem;cursor:pointer;transition:all .15s;text-transform:uppercase}.plus1 .plus{font-weight:700;font-size:.95rem;line-height:1}.plus1 .count{min-width:1.2rem;text-align:center}.plus1:hover{color:var(--ink);border-color:var(--ink)}.plus1.on{background:var(--accent);border-color:var(--accent);color:var(--bg-elev)}.plus1.on:hover{background:var(--ink);border-color:var(--ink)}.plus1.large{padding:.6rem 1.1rem;font-size:.85rem;letter-spacing:.2em;margin-top:1.5rem}.resonance-bar{display:flex;gap:1rem;align-items:center}.onboard{max-width:1000px;margin:0 auto;padding:2rem 0}.onboard-head{text-align:center;margin-bottom:3rem}.onboard-head .mini{font-family:var(--font-display);font-size:.75rem;letter-spacing:.4em;color:var(--ink-dim);text-transform:uppercase;margin-bottom:.5rem}.onboard-head h1{font-size:4.5rem;line-height:1;letter-spacing:-.04em}.onboard-head p{color:var(--ink-dim);font-size:1.05rem;max-width:32rem;margin:1rem auto 0}.onboard-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:2.5rem}.onboard-card{background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem;position:relative}.onboard-card .num{position:absolute;top:1rem;right:1.25rem;font-family:var(--font-display);font-size:.85rem;letter-spacing:.1em;color:var(--ink-soft)}.onboard-card .ttl{font-family:var(--font-display);font-weight:700;font-size:1.4rem;letter-spacing:.05em;text-transform:uppercase;margin-bottom:.75rem}.onboard-card p{color:var(--ink-dim);font-size:.95rem;line-height:1.55;margin:0}.onboard-cta{text-align:center}.onboard-cta button{font-size:.95rem;letter-spacing:.25em;padding:1rem 2.5rem}@media (max-width: 720px){.onboard-grid{grid-template-columns:1fr}.onboard-head h1{font-size:3rem}}.disc-wrap{position:fixed;top:60px;right:0;bottom:0;left:0;background:var(--bg);overflow:hidden}.disc-canvas{position:absolute;top:0;right:0;bottom:0;left:0}.disc-overlay{position:absolute;top:1rem;left:1rem;display:flex;flex-direction:column;gap:.6rem;z-index:2;max-width:360px}.disc-toggle-row{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.disc-status{color:var(--ink-dim);font-size:.78rem;margin-left:.25rem}.disc-explain{background:#f6f3eceb;border:1px solid var(--line);border-radius:var(--radius);padding:.7rem .85rem;color:var(--ink-dim);font-size:.78rem;line-height:1.5;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.disc-explain b{color:var(--ink)}.disc-friends{background:#f6f3eceb;border:1px solid var(--line);border-radius:var(--radius);padding:.7rem .85rem;font-size:.82rem;max-height:280px;overflow-y:auto;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.disc-friends-head{font-family:var(--font-display);font-size:.7rem;letter-spacing:.2em;color:var(--ink-soft);margin-bottom:.5rem;text-transform:uppercase}.disc-friend{display:flex;align-items:center;gap:.5rem;padding:.3rem 0;cursor:pointer}.disc-friend input{width:auto;margin:0}.disc-friends-empty{color:var(--ink-dim)}.disc-friends-empty a{color:var(--accent)}.disc-legend{position:absolute;top:1rem;right:1rem;z-index:2;background:#f6f3eceb;border:1px solid var(--line);border-radius:var(--radius);padding:.6rem .85rem;font-size:.78rem;color:var(--ink-dim);line-height:1.7;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.disc-legend .dot{display:inline-block;width:11px;height:11px;border-radius:50%;vertical-align:middle;margin-right:6px}.disc-legend .dot.mine{background:#d94f3c;box-shadow:0 0 6px #d94f3c80}.disc-legend .dot.other{background:#222}.disc-legend .dot.halo{background:transparent;border:2px solid #c89a2e;width:13px;height:13px}.disc-hint{position:absolute;bottom:1rem;left:1rem;color:var(--ink-soft);font-size:.78rem;z-index:2}.disc-hint b{color:var(--accent);font-weight:600}.disc-tip{position:absolute;pointer-events:none;display:none;background:#f6f3ecf7;border:1px solid var(--ink);border-radius:var(--radius);padding:.6rem;z-index:3;width:240px;font-size:.82rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 6px 20px #0000001f}.disc-tip img{width:100%;border-radius:3px;margin-bottom:.4rem;display:block}.disc-tip .tip-song{font-family:var(--font-display);font-weight:600;color:var(--ink)}.disc-tip .tip-artist{color:var(--ink-dim)}.disc-tip .tip-author{color:var(--ink-soft);margin-top:.3rem;font-size:.75rem}.disc-tip .tip-feelings{margin-top:.4rem;font-family:var(--font-display);font-size:.7rem;letter-spacing:.08em;color:var(--accent);text-transform:lowercase}.disc-labels{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:2}.cluster-label{position:absolute;pointer-events:auto;font-family:var(--font-display);font-weight:700;font-size:.72rem;letter-spacing:.18em;background:var(--ink);color:var(--bg-elev);padding:.32rem .65rem .32rem .55rem;border-radius:999px;white-space:nowrap;text-transform:uppercase;display:inline-flex;align-items:center;gap:.35rem;cursor:pointer;transition:background .15s}.cluster-label:hover{background:var(--accent);color:var(--bg-elev)}.cluster-label .cluster-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--accent)}.cluster-label:hover .cluster-dot{background:var(--bg-elev)}.cluster-dot-anchor{position:absolute;pointer-events:auto;width:18px;height:18px;margin:-9px 0 0 -9px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;text-decoration:none}.cluster-dot-anchor .dot{width:14px;height:14px;border-radius:50%;background:var(--dot, #888);box-shadow:0 0 0 2px #f6f3ecd9,0 0 10px #0000002e;transition:transform .15s}.cluster-dot-anchor:hover .dot{transform:scale(1.45)}.cluster-dot-anchor .tip{position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);font-family:var(--font-display);font-weight:700;font-size:.68rem;letter-spacing:.16em;background:var(--ink);color:var(--bg-elev);padding:.3rem .55rem;border-radius:999px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .12s}.cluster-dot-anchor:hover .tip{opacity:1}.genre-label{position:absolute;pointer-events:none;font-family:var(--font-serif, Georgia, serif);font-style:italic;font-size:.95rem;color:var(--ink);background:#f6f3ecc7;padding:.15rem .5rem;border-radius:4px;white-space:nowrap;letter-spacing:.02em;text-shadow:0 0 4px rgba(246,243,236,.9)}.disc-legend .legend-title{font-family:var(--font-display);font-size:.7rem;letter-spacing:.22em;color:var(--ink);font-weight:700;margin-bottom:.2rem;text-transform:uppercase}.disc-legend .legend-sub{font-size:.7rem;color:var(--ink-soft);margin-bottom:.5rem;font-style:italic;max-width:280px;line-height:1.35}.disc-legend .legend-row{display:flex;flex-wrap:wrap;gap:.5rem .85rem;max-width:280px}.disc-legend .legend-chip{display:inline-flex;align-items:center;gap:.35rem;font-size:.74rem}.disc-legend .legend-swatch{width:11px;height:11px;border-radius:50%;display:inline-block}.room-page{display:grid;grid-template-columns:1.4fr 1fr;gap:1.5rem;margin-top:1rem}.room-songs .mini,.room-chat .mini{font-family:var(--font-display);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-dim)}.room-title{font-size:4rem;line-height:1;margin:.4rem 0 .5rem}.room-sub{color:var(--ink-dim);margin-bottom:1.5rem}.room-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem}.room-card{display:flex;gap:.75rem;align-items:center;background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius);padding:.75rem;text-decoration:none;color:var(--ink);transition:border-color .15s}.room-card:hover{border-color:var(--ink)}.room-card img,.room-card .ph{width:56px;height:56px;border-radius:3px;background:var(--bg);object-fit:cover;flex-shrink:0}.room-card-info{min-width:0}.room-card .song{font-family:var(--font-display);font-weight:600;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.room-card .artist{color:var(--ink-dim);font-size:.78rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.room-card .author{color:var(--ink-soft);font-size:.72rem;margin-top:.2rem}.room-card{position:relative}.room-card-badge{display:inline-block;background:var(--ink);color:var(--bg-elev);font-family:var(--font-display);font-size:.65rem;letter-spacing:.08em;padding:1px 6px;border-radius:999px;vertical-align:middle;margin-left:.35rem}.room-card-rank{position:absolute;top:-8px;left:8px;background:var(--accent, #d94f3c);color:#fff;font-family:var(--font-display);font-size:.58rem;letter-spacing:.18em;padding:2px 6px;border-radius:3px}.room-chat{position:sticky;top:80px;align-self:start;border:1px solid var(--line);border-radius:var(--radius);padding:1rem;height:calc(100vh - 120px);display:flex;flex-direction:column}.room-messages{flex:1;overflow-y:auto;margin:.75rem 0;display:flex;flex-direction:column;gap:.6rem;padding-right:.25rem}.room-msg{background:var(--bg-elev);border:1px solid var(--line);border-radius:8px;padding:.5rem .7rem;align-self:flex-start;max-width:85%}.room-msg.mine{align-self:flex-end;background:var(--ink);color:var(--bg-elev);border-color:var(--ink)}.room-msg .who{font-family:var(--font-display);font-size:.7rem;letter-spacing:.1em;color:var(--ink-soft);margin-bottom:.2rem}.room-msg.mine .who{color:var(--bg);opacity:.7}.room-msg .text{font-size:.92rem;line-height:1.4;word-wrap:break-word}.room-form{display:flex;gap:.5rem}.room-form input{flex:1;margin:0}.room-form button{white-space:nowrap}@media (max-width: 860px){.room-page{grid-template-columns:1fr}.room-chat{position:relative;top:0;height:60vh}.room-title{font-size:2.5rem}}.memory-page{max-width:760px}.memory-photo{width:100%;max-height:480px;object-fit:cover;border-radius:var(--radius);margin-top:1rem}.feeling-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin:1.25rem 0 0}.feeling-tag{font-family:var(--font-display);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);background:var(--bg-elev);border:1px solid var(--line);padding:.3rem .65rem;border-radius:999px;text-decoration:none;transition:all .15s}.feeling-tag:hover{background:var(--accent);color:var(--bg-elev);border-color:var(--accent)}.photo-row{display:flex;gap:1rem;align-items:center;margin-bottom:1rem}.photo-row input[type=file]{background:transparent;border:1px dashed var(--line);padding:.6rem;width:auto;margin:0;font-size:.85rem;color:var(--ink-dim);cursor:pointer}.photo-preview{width:80px;height:80px;border-radius:var(--radius);background:var(--bg);border:1px solid var(--line);overflow:hidden;display:flex;align-items:center;justify-content:center}.photo-preview img{width:100%;height:100%;object-fit:cover}.user-row{display:flex;justify-content:space-between;align-items:center;padding:.6rem 0;border-bottom:1px solid var(--line);gap:.75rem}.user-row:last-child{border-bottom:none}.user-row .song{font-family:var(--font-display);font-weight:600;font-size:.95rem}.user-row button{padding:.4rem .9rem;font-size:.72rem}.archive-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.75rem}.archive-card{display:flex;gap:.75rem;align-items:center;background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius);padding:.75rem;text-decoration:none;color:var(--ink);transition:border-color .15s}.archive-card:hover{border-color:var(--ink)}.archive-card img,.archive-card .ph{width:52px;height:52px;border-radius:3px;background:var(--bg);object-fit:cover;flex-shrink:0}.archive-card .info{min-width:0}.archive-card .song{font-family:var(--font-display);font-weight:600;font-size:.88rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.archive-card .artist{color:var(--ink-dim);font-size:.75rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.archive-card .meta{color:var(--ink-soft);font-size:.7rem;margin-top:.2rem}
