.street-wall-module__QPLRvG__wallViewport{cursor:crosshair;background-color:#3a3632;width:100vw;height:100vh;position:relative;overflow:hidden}.street-wall-module__QPLRvG__wallSurface{image-rendering:auto;background-image:url(/images/graffiti/concrete-wall.png);background-repeat:repeat;background-size:600px 600px;position:absolute;inset:0}.street-wall-module__QPLRvG__wallSurface:after{content:"";pointer-events:none;background:repeating-linear-gradient(90deg,#0000,#0000 200px,#00000005 200px 201px),repeating-linear-gradient(0deg,#0000,#0000 200px,#00000004 200px 201px);position:absolute;inset:0}.street-wall-module__QPLRvG__vignette{pointer-events:none;z-index:2;background:radial-gradient(#0000 40%,#00000073 100%);position:absolute;inset:0}.street-wall-module__QPLRvG__spotlight{pointer-events:none;z-index:3;transition:background 80ms;position:absolute;inset:0}.street-wall-module__QPLRvG__graffitiItem{cursor:pointer;z-index:4;filter:drop-shadow(2px 3px 6px #0006);border-radius:3px;transition:filter .3s,transform .2s;position:absolute}.street-wall-module__QPLRvG__graffitiItem:hover{filter:drop-shadow(2px 3px 12px #0009)drop-shadow(0 0 20px #39ff1426);z-index:5;transform:scale(1.03)}.street-wall-module__QPLRvG__graffitiItem img{object-fit:contain;border-radius:3px;width:100%;height:100%;display:block}.street-wall-module__QPLRvG__headerBar{z-index:30;pointer-events:none;background:linear-gradient(#000000b3 0%,#0000 100%);justify-content:space-between;align-items:center;padding:16px 24px;display:flex;position:fixed;top:0;left:0;right:0}.street-wall-module__QPLRvG__headerBar>*{pointer-events:auto}.street-wall-module__QPLRvG__headerTitle{color:#e0ddd8;letter-spacing:4px;text-transform:uppercase;text-shadow:0 0 20px #39ff144d;pointer-events:none;font-family:Courier New,monospace;font-size:1.25rem;font-weight:900;position:absolute;left:50%;transform:translate(-50%)}.street-wall-module__QPLRvG__headerActions{align-items:center;gap:10px;display:flex}.street-wall-module__QPLRvG__headerBtn{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#e0ddd8;letter-spacing:1px;text-transform:uppercase;cursor:pointer;background:#00000080;border:1px solid #fff3;border-radius:6px;align-items:center;gap:6px;padding:8px 16px;font-family:Courier New,monospace;font-size:.8rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.street-wall-module__QPLRvG__headerBtn:hover{color:#39ff14;border-color:#39ff14;box-shadow:0 0 15px #39ff1426}.street-wall-module__QPLRvG__hintText{z-index:30;color:#e0ddd880;letter-spacing:2px;text-transform:uppercase;pointer-events:none;font-family:Courier New,monospace;font-size:.75rem;animation:3s ease-in-out infinite street-wall-module__QPLRvG__hintPulse;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}@keyframes street-wall-module__QPLRvG__hintPulse{0%,to{opacity:.4}50%{opacity:.8}}.street-wall-module__QPLRvG__sizePickerOverlay{z-index:40;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.street-wall-module__QPLRvG__sizePickerBackdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;position:absolute;inset:0}.street-wall-module__QPLRvG__sizePickerCard{z-index:1;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#1e1c1af2;border:1px solid #ffffff1a;border-radius:16px;min-width:320px;padding:28px 32px;position:relative}.street-wall-module__QPLRvG__sizePickerTitle{color:#e0ddd8;letter-spacing:3px;text-transform:uppercase;text-align:center;margin-bottom:20px;font-family:Courier New,monospace;font-size:.9rem;font-weight:700}.street-wall-module__QPLRvG__sizeOptions{justify-content:center;gap:12px;display:flex}.street-wall-module__QPLRvG__sizeOption{cursor:pointer;color:#bbb;background:#ffffff08;border:1px solid #ffffff1a;border-radius:12px;flex-direction:column;flex:1;align-items:center;gap:8px;padding:16px 20px;transition:all .25s;display:flex}.street-wall-module__QPLRvG__sizeOption:hover{color:#39ff14;background:#39ff140d;border-color:#39ff14}.street-wall-module__QPLRvG__sizeOptionActive{box-shadow:0 0 20px #39ff141a;color:#39ff14!important;background:#39ff141a!important;border-color:#39ff14!important}.street-wall-module__QPLRvG__sizePreview{border:2px dashed;border-radius:4px;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.street-wall-module__QPLRvG__sizePreviewInner{opacity:.3;background:currentColor;border-radius:2px}.street-wall-module__QPLRvG__sizeLabel{letter-spacing:2px;text-transform:uppercase;font-family:Courier New,monospace;font-size:.7rem;font-weight:600}.street-wall-module__QPLRvG__sizePickerActions{gap:10px;margin-top:20px;display:flex}.street-wall-module__QPLRvG__btnCancel{color:#999;letter-spacing:1px;text-transform:uppercase;cursor:pointer;background:0 0;border:1px solid #ffffff1a;border-radius:8px;flex:1;padding:10px;font-family:Courier New,monospace;font-size:.75rem;font-weight:600;transition:all .2s}.street-wall-module__QPLRvG__btnCancel:hover{color:#ff2d7b;border-color:#ff2d7b}.street-wall-module__QPLRvG__btnConfirm{color:#39ff14;letter-spacing:1px;text-transform:uppercase;cursor:pointer;background:#39ff141a;border:1px solid #39ff14;border-radius:8px;flex:1;padding:10px;font-family:Courier New,monospace;font-size:.75rem;font-weight:600;transition:all .2s}.street-wall-module__QPLRvG__btnConfirm:hover{background:#39ff1433;box-shadow:0 0 20px #39ff1433}.street-wall-module__QPLRvG__modalOverlay{z-index:50;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.street-wall-module__QPLRvG__modalCard{background:#1a1816;border:1px solid #ffffff14;border-radius:16px;flex-direction:column;max-width:90vw;max-height:90vh;padding:20px;display:flex;position:relative;overflow-y:auto;box-shadow:0 25px 60px #00000080}.street-wall-module__QPLRvG__modalTitle{color:#e0ddd8;letter-spacing:3px;text-transform:uppercase;text-align:center;margin-bottom:14px;font-family:Courier New,monospace;font-size:.85rem;font-weight:700}.street-wall-module__QPLRvG__toolbar{background:#ffffff0a;border:1px solid #ffffff0f;border-radius:10px;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:12px;padding:10px 12px;display:flex}.street-wall-module__QPLRvG__toolGroup{align-items:center;gap:6px;display:flex}.street-wall-module__QPLRvG__toolDivider{background:#ffffff1a;width:1px;height:24px;margin:0 4px}.street-wall-module__QPLRvG__toolBtn{color:#999;cursor:pointer;background:0 0;border:1px solid #ffffff14;border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;font-size:1rem;transition:all .15s;display:inline-flex}.street-wall-module__QPLRvG__toolBtn:hover{color:#e0ddd8;background:#ffffff0d;border-color:#fff3}.street-wall-module__QPLRvG__toolBtnActive{color:#39ff14!important;background:#39ff1414!important;border-color:#39ff14!important}.street-wall-module__QPLRvG__colorInput{cursor:pointer;background:0 0;border:none;border-radius:8px;width:34px;height:34px;padding:0}.street-wall-module__QPLRvG__colorInput::-webkit-color-swatch-wrapper{padding:3px}.street-wall-module__QPLRvG__colorInput::-webkit-color-swatch{border:1px solid #ffffff26;border-radius:5px}.street-wall-module__QPLRvG__sizeSlider{accent-color:#39ff14;cursor:pointer;width:80px}.street-wall-module__QPLRvG__sizeValue{color:#777;text-align:center;min-width:24px;font-family:Courier New,monospace;font-size:.7rem}.street-wall-module__QPLRvG__canvasContainer{background:#111;border:1px solid #ffffff14;border-radius:10px;flex:auto;min-height:0;position:relative;overflow:hidden}.street-wall-module__QPLRvG__canvas{touch-action:none;max-width:100%;max-height:100%;display:block}.street-wall-module__QPLRvG__modalActions{gap:10px;margin-top:14px;display:flex}.street-wall-module__QPLRvG__btnSave{color:#39ff14;letter-spacing:2px;text-transform:uppercase;cursor:pointer;background:#39ff141a;border:1px solid #39ff14;border-radius:10px;flex:1;padding:12px;font-family:Courier New,monospace;font-size:.8rem;font-weight:700;transition:all .2s}.street-wall-module__QPLRvG__btnSave:hover{background:#39ff1433;box-shadow:0 0 25px #39ff1433}.street-wall-module__QPLRvG__btnDiscard{color:#999;letter-spacing:2px;text-transform:uppercase;cursor:pointer;background:0 0;border:1px solid #ffffff1a;border-radius:10px;flex:1;padding:12px;font-family:Courier New,monospace;font-size:.8rem;font-weight:700;transition:all .2s}.street-wall-module__QPLRvG__btnDiscard:hover{color:#ff2d7b;border-color:#ff2d7b}.street-wall-module__QPLRvG__lightboxOverlay{z-index:50;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#000c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.street-wall-module__QPLRvG__lightboxCard{background:#1a1816;border:1px solid #ffffff14;border-radius:16px;flex-direction:column;align-items:center;max-width:85vw;max-height:85vh;padding:24px;display:flex;position:relative;box-shadow:0 30px 80px #0009}.street-wall-module__QPLRvG__lightboxImage{object-fit:contain;border-radius:8px;max-width:100%;max-height:60vh}.street-wall-module__QPLRvG__lightboxMeta{text-align:center;margin-top:16px}.street-wall-module__QPLRvG__lightboxAuthor{color:#999;letter-spacing:1px;font-family:Courier New,monospace;font-size:.8rem}.street-wall-module__QPLRvG__lightboxDate{color:#666;margin-top:4px;font-family:Courier New,monospace;font-size:.7rem}.street-wall-module__QPLRvG__lightboxActions{gap:16px;margin-top:20px;display:flex}.street-wall-module__QPLRvG__actionBtn{color:#bbb;cursor:pointer;background:#ffffff08;border:1px solid #ffffff1a;border-radius:10px;align-items:center;gap:8px;padding:10px 20px;font-family:Courier New,monospace;font-size:.8rem;font-weight:600;transition:all .2s;display:inline-flex}.street-wall-module__QPLRvG__actionBtn:hover{background:#ffffff0f;border-color:#ffffff40}.street-wall-module__QPLRvG__actionBtnLiked{color:#ff2d7b!important;background:#ff2d7b1a!important;border-color:#ff2d7b!important}.street-wall-module__QPLRvG__actionBtnBookmarked{color:gold!important;background:#ffd7001a!important;border-color:gold!important}.street-wall-module__QPLRvG__lightboxClose{color:#999;cursor:pointer;background:#0006;border:1px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.1rem;transition:all .2s;display:flex;position:absolute;top:12px;right:12px}.street-wall-module__QPLRvG__lightboxClose:hover{color:#ff2d7b;border-color:#ff2d7b}.street-wall-module__QPLRvG__heartBurst{pointer-events:none;z-index:100;position:absolute}.street-wall-module__QPLRvG__heartParticle{font-size:1rem;animation:.8s ease-out forwards street-wall-module__QPLRvG__heartFloat;position:absolute}@keyframes street-wall-module__QPLRvG__heartFloat{0%{opacity:1;transform:translate(0)scale(1)}to{opacity:0;transform:translate(var(--tx),var(--ty))scale(.5)}}.street-wall-module__QPLRvG__graffitiEntrance{animation:.5s cubic-bezier(.34,1.56,.64,1) both street-wall-module__QPLRvG__popIn}@keyframes street-wall-module__QPLRvG__popIn{0%{opacity:0;transform:scale(.5)rotate(-5deg)}to{opacity:1;transform:scale(1)rotate(0)}}@keyframes street-wall-module__QPLRvG__sprayBurst{0%{opacity:1;transform:scale(1)}50%{opacity:.8;filter:blur(2px);transform:scale(1.15)}to{opacity:1;filter:blur();transform:scale(1)}}.street-wall-module__QPLRvG__sprayEffect{animation:.6s ease-out street-wall-module__QPLRvG__sprayBurst}.street-wall-module__QPLRvG__sidebarToggle{z-index:36;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#bbb;cursor:pointer;writing-mode:vertical-rl;text-orientation:mixed;background:#141210d9;border:1px solid #ffffff1a;border-right:none;border-radius:8px 0 0 8px;align-items:center;gap:4px;padding:12px 8px;font-size:.75rem;transition:all .2s;display:flex;position:fixed;top:50%;right:0;transform:translateY(-50%)}.street-wall-module__QPLRvG__sidebarToggle:hover{color:#39ff14;background:#1e1c1af2;border-color:#39ff1433}.street-wall-module__QPLRvG__sidebarToggleLabel{letter-spacing:2px;text-transform:uppercase;font-family:Courier New,monospace;font-size:.65rem;font-weight:700}.street-wall-module__QPLRvG__sidebarPanel{z-index:35;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#12100eeb;border-left:1px solid #ffffff14;flex-direction:column;width:280px;height:100vh;display:flex;position:fixed;top:0;right:0;overflow:hidden}.street-wall-module__QPLRvG__sidebarTabs{border-bottom:1px solid #ffffff0f;flex-shrink:0;display:flex}.street-wall-module__QPLRvG__sidebarTab{color:#777;letter-spacing:1px;text-transform:uppercase;cursor:pointer;background:0 0;border:none;flex:1;justify-content:center;align-items:center;gap:6px;padding:16px 8px;font-family:Courier New,monospace;font-size:.7rem;font-weight:700;transition:all .2s;display:flex}.street-wall-module__QPLRvG__sidebarTab:hover{color:#ccc;background:#ffffff08}.street-wall-module__QPLRvG__sidebarTabActive{border-bottom:2px solid #39ff14;color:#39ff14!important;background:#39ff1408!important}.street-wall-module__QPLRvG__sidebarCount{min-width:20px;height:18px;color:inherit;background:#ffffff14;border-radius:9px;justify-content:center;align-items:center;padding:0 5px;font-size:.6rem;font-weight:700;display:inline-flex}.street-wall-module__QPLRvG__sidebarGrid{flex:1;grid-template-columns:repeat(2,1fr);align-content:start;gap:10px;padding:12px;display:grid;overflow-y:auto}.street-wall-module__QPLRvG__sidebarGrid::-webkit-scrollbar{width:4px}.street-wall-module__QPLRvG__sidebarGrid::-webkit-scrollbar-track{background:0 0}.street-wall-module__QPLRvG__sidebarGrid::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.street-wall-module__QPLRvG__sidebarEmpty{text-align:center;color:#555;white-space:pre-line;grid-column:1/-1;padding:40px 12px;font-family:Courier New,monospace;font-size:.7rem;line-height:1.8}.street-wall-module__QPLRvG__sidebarThumb{aspect-ratio:1;cursor:pointer;background:#ffffff05;border:1px solid #ffffff0f;border-radius:8px;padding:0;transition:all .2s;position:relative;overflow:hidden}.street-wall-module__QPLRvG__sidebarThumb:hover{border-color:#39ff144d;transform:scale(1.04);box-shadow:0 4px 16px #0006}.street-wall-module__QPLRvG__sidebarThumb img{object-fit:contain;width:100%;height:100%;display:block}.street-wall-module__QPLRvG__sidebarThumbMeta{color:#ccc;opacity:0;background:linear-gradient(#0000,#000000b3);justify-content:flex-end;padding:4px 6px;font-family:Courier New,monospace;font-size:.6rem;transition:opacity .2s;display:flex;position:absolute;bottom:0;left:0;right:0}.street-wall-module__QPLRvG__sidebarThumb:hover .street-wall-module__QPLRvG__sidebarThumbMeta{opacity:1}@media (max-width:768px){.street-wall-module__QPLRvG__wallViewport{height:auto;min-height:100vh;overflow-y:auto}.street-wall-module__QPLRvG__headerBar{padding:12px 16px}.street-wall-module__QPLRvG__headerTitle{letter-spacing:2px;font-size:.9rem}.street-wall-module__QPLRvG__sizePickerCard{min-width:unset;width:90vw;padding:20px}.street-wall-module__QPLRvG__sizeOptions{flex-direction:column}.street-wall-module__QPLRvG__modalCard{width:95vw;padding:14px}.street-wall-module__QPLRvG__toolbar{gap:6px;padding:8px}.street-wall-module__QPLRvG__lightboxCard{width:95vw;padding:16px}.street-wall-module__QPLRvG__sidebarPanel{width:220px}.street-wall-module__QPLRvG__sidebarToggle{padding:10px 6px}}
