@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}}:root{letter-spacing:-.02em;color:#1a1a1a;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;font-family:DM Sans,system-ui,-apple-system,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}#root{min-height:100vh}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}:root{--app-bg: radial-gradient(ellipse 100% 80% at 50% 10%, #ffffff 0%, #e8e3da 100%);--sidebar-border: rgba(0, 0, 0, .07);--color-title: #2a1e0e;--color-text: #444;--color-muted: #666;--color-footer-name: #2a1e0e;--color-footer-link: #888;--color-footer-hover: #2a1e0e;--sidebar-hover-bg: rgba(0, 0, 0, .06);--card-bg: #f5f0e8;--card-close-bg: rgba(0, 0, 0, .1);--card-close-color: #333;--card-close-hover-bg: rgba(0, 0, 0, .2);--paper-bg: #e8dfd0;--paper-gradient: linear-gradient(180deg, #e8dfd0 0%, #ddd4c4 100%);--paper-shadow: inset 0 1px 0 rgba(255, 255, 255, .3), 0 2px 8px rgba(0, 0, 0, .08);--paper-border: rgba(139, 105, 20, .15);--ficha-label: #4a4a4a;--ficha-value: #1a1a1a;--ficha-line: rgba(0, 0, 0, .15);--heading-album: #1a1a1a;--heading-artist: #666;--tracks-title: #333;--tracks-item: #1a1a1a;--streaming-icon: #999;--tidal-hover: #000;--theme-btn: #999;--theme-btn-hover: #2a1e0e;--sidebar-bg: #f0ebe0;--shelf-noise: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.22'/%3E%3C/svg%3E");--shelf-bg: var(--shelf-noise), radial-gradient(ellipse 100% 80% at 50% 10%, #ffffff 0%, #e8e3da 100%)}[data-theme=dark]{--app-bg: radial-gradient(ellipse 100% 80% at 50% 10%, #1c1916 0%, #120f0c 100%);--sidebar-border: rgba(255, 255, 255, .07);--color-title: #f0e6d0;--color-text: #9a9285;--color-muted: #9f9485;--color-footer-name: #f0e6d0;--color-footer-link: #5a5248;--color-footer-hover: #f0e6d0;--sidebar-hover-bg: rgba(255, 255, 255, .06);--card-bg: #1e1b16;--card-close-bg: rgba(255, 255, 255, .1);--card-close-color: #c0b8a8;--card-close-hover-bg: rgba(255, 255, 255, .18);--paper-bg: #26211a;--paper-gradient: linear-gradient(180deg, #26211a 0%, #201c15 100%);--paper-shadow: inset 0 1px 0 rgba(255, 255, 255, .04), 0 2px 8px rgba(0, 0, 0, .4);--paper-border: rgba(180, 140, 60, .12);--ficha-label: #6a6258;--ficha-value: #ddd5c5;--ficha-line: rgba(255, 255, 255, .1);--heading-album: #f0e6d0;--heading-artist: #8a8278;--tracks-title: #b0a898;--tracks-item: #ddd5c5;--streaming-icon: #5a5248;--tidal-hover: #f0e6d0;--theme-btn: #5a5248;--theme-btn-hover: #f0e6d0;--sidebar-bg: #161310;--shelf-noise: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.07'/%3E%3C/svg%3E");--shelf-bg: var(--shelf-noise), radial-gradient(ellipse 100% 80% at 50% 10%, #1c1916 0%, #120f0c 100%)}.app{min-height:100vh;transition:background .3s}.layout{display:grid;grid-template-columns:280px 1fr;min-height:100vh}.sidebar{display:flex;flex-direction:column;justify-content:space-between;padding:3rem 2rem;position:sticky;top:0;height:100vh;background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);transition:background .3s,border-color .3s}.sidebar-content{display:flex;flex-direction:column;gap:1.5rem}.shelf-title{font-size:2rem;font-weight:700;color:var(--color-title);letter-spacing:-.03em;margin:0;line-height:1.15;transition:color .3s}.sidebar-about{font-size:.88rem;color:var(--color-muted);line-height:1.6;margin:0;transition:color .3s}.sidebar-links{display:flex;flex-direction:column;gap:.2rem;margin-top:.5rem}.sidebar-link{display:flex;align-items:left;gap:.6rem;font-size:.85rem;font-weight:500;color:var(--color-text);text-decoration:none;padding:.5rem .75rem;border-radius:8px;transition:background .15s,color .15s}.sidebar-link svg{width:18px;height:18px;flex-shrink:0}.sidebar-link:hover{background:var(--sidebar-hover-bg)}.sidebar-link--lastfm:hover{color:#d51007}.sidebar-link--spotify:hover{color:#1db954}.mobile-theme-toggle{display:none}.theme-toggle{display:flex;align-items:center;background:none;border:none;padding:.3rem;border-radius:6px;cursor:pointer;color:var(--theme-btn);transition:color .15s,background .15s}.theme-toggle:hover{color:var(--theme-btn-hover);background:var(--sidebar-hover-bg)}.theme-toggle svg{width:20px;height:20px;flex-shrink:0}.now-playing{display:flex;flex-direction:column;gap:.2rem;padding-bottom:.75rem;text-decoration:none;border-radius:6px;padding:.5rem;margin:-.5rem -.5rem .25rem;transition:background .15s ease,opacity .15s ease}.now-playing:hover{background:var(--now-playing-hover, rgba(0, 0, 0, .05));opacity:.85}[data-theme=dark]{--now-playing-hover: rgba(255, 255, 255, .06)}.now-playing-status{display:flex;align-items:center;gap:.4rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-muted)}.now-playing-bars{display:flex;align-items:flex-end;gap:2px;height:12px;flex-shrink:0}.now-playing-bars span{display:block;width:3px;border-radius:1px;background:#5bbb7b;animation:eq-bar 1s ease-in-out infinite alternate}.now-playing-bars span:nth-child(1){animation-duration:.9s;animation-delay:0s}.now-playing-bars span:nth-child(2){animation-duration:.7s;animation-delay:.15s}.now-playing-bars span:nth-child(3){animation-duration:1.1s;animation-delay:.05s}.now-playing-bars span:nth-child(4){animation-duration:.8s;animation-delay:.25s}@keyframes eq-bar{0%{height:3px;opacity:.7}to{height:12px;opacity:1}}.now-playing-title{font-size:.85rem;font-weight:600;color:var(--color-title);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .3s}.now-playing-artist{font-size:.8rem;color:var(--color-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .3s}.site-footer{display:flex;flex-direction:column;gap:2rem}.site-footer-bottom{display:flex;align-items:center;justify-content:space-between}.site-footer-info{display:flex;flex-direction:column;gap:.25rem}.site-footer-name{font-size:1rem;font-weight:600;color:var(--color-footer-name);transition:color .3s}.site-footer-madein{font-size:.75rem;color:var(--color-muted);transition:color .3s}.site-footer-portfolio{font-size:.8rem;color:var(--color-footer-link);text-decoration:none;transition:color .15s}.site-footer-portfolio:hover{color:var(--color-footer-hover)}.shelf-wrapper{overflow-y:auto;overflow-x:hidden;min-width:0;background:var(--shelf-bg);transition:background .3s}.shelf-page{padding:5rem 6rem 2rem;width:100%}.shelf-container{display:flex;flex-direction:column;gap:2rem}.shelf-scroll-hint{position:fixed;bottom:1.75rem;left:calc(50vw + 140px);transform:translate(-50%);pointer-events:auto;color:var(--color-muted);opacity:0;transition:opacity .4s}.shelf-scroll-hint--visible{opacity:1;animation:hint-bounce 1.8s ease-in-out infinite}.shelf-scroll-hint__tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);white-space:nowrap;font-size:.7rem;font-weight:500;color:var(--color-muted);opacity:0;transition:opacity .2s;pointer-events:none}.shelf-scroll-hint:hover .shelf-scroll-hint__tooltip{opacity:1}@keyframes hint-bounce{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(5px)}}.shelf-row{display:flex;flex-direction:column;align-items:stretch;opacity:0;transform:translateY(32px);transition:opacity .5s ease,transform .5s ease}.shelf-row--visible{opacity:1;transform:translateY(0)}.shelf-slots{display:grid;grid-template-columns:repeat(var(--cols, 4),1fr);gap:0rem;align-items:flex-end;padding:0;position:relative;z-index:2}.shelf-plank{width:100%;position:relative;z-index:1;margin-top:-6px}.shelf-plank-top{height:12px;border-radius:4px 4px 0 0;background:linear-gradient(to bottom,#e6ccb2,#ddb892);box-shadow:inset 0 1px #fff6}.shelf-plank-face{height:16px;border-radius:0 0 4px 4px;background:linear-gradient(to bottom,#b08968,#9c6644);box-shadow:0 8px 8px #0000004d;display:flex;align-items:center;padding:0 16px}.shelf-plank-line{width:100%;height:1px;background:#0000001a}.shelf-plank-shadow{height:32px;background:linear-gradient(to bottom,rgba(0,0,0,.2),transparent);filter:blur(12px)}.vinyl{width:100%;max-width:200px;justify-self:center;padding:0;border:none;background:transparent;cursor:pointer;border-radius:3px;transition:transform .25s ease}.vinyl:hover{transform:translateY(-8px)}.vinyl-tooltip{display:none;position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%);background:#140e06d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;padding:6px 10px;border-radius:6px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .2s;flex-direction:column;gap:1px;z-index:10}.vinyl-tooltip-album{font-size:.75rem;font-weight:700;line-height:1.2}.vinyl-tooltip-artist{font-size:.68rem;font-weight:400;color:#ffffffb3}.vinyl:focus-visible{outline:2px solid #8b6914;outline-offset:3px}.vinyl-inner{width:100%;aspect-ratio:1;height:auto;border-radius:3px;overflow:hidden;background:#fff;box-shadow:0 1px 3px #00000038,0 10px 22px #0000002e}.vinyl-cover{width:100%;height:100%;object-fit:cover;display:block}.vinyl-placeholder{width:100%;height:100%;background:linear-gradient(145deg,#3d3d3d,#2a2a2a);display:flex;align-items:center;justify-content:center;padding:.5rem}.vinyl-placeholder-text{font-size:.7rem;color:#ffffffd9;text-align:center;line-height:1.2;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.card-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100;padding:1.5rem;animation:overlayIn .25s ease}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}.card-modal{background:var(--card-bg);border-radius:12px;max-width:560px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000059;position:relative;animation:cardIn .3s ease;transition:background .3s}@keyframes cardIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.card-overlay-out{animation:overlayOut .25s ease forwards}.card-modal-out{animation:cardOut .25s ease forwards}@keyframes overlayOut{to{opacity:0}}@keyframes cardOut{to{opacity:0;transform:scale(.95)}}.card-close{position:absolute;top:.75rem;right:.75rem;width:36px;height:36px;border:none;background:var(--card-close-bg);color:var(--card-close-color);font-size:1.5rem;line-height:1;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:2;transition:background .2s}.card-close:hover{background:var(--card-close-hover-bg)}.card-top{display:flex;justify-content:center;align-items:center;padding:1.5rem 1.5rem 0;min-height:200px}.card-top-frame{position:relative;width:230px;height:160px}.card-cover-wrap{position:absolute;left:0;top:0;width:160px;height:160px;border-radius:6px;overflow:hidden;box-shadow:0 6px 20px #00000040;z-index:1;background:#1a1a1a}.card-cover{width:100%;height:100%;object-fit:cover;display:block;border-radius:6px}.card-cover-placeholder{width:100%;height:100%;background:linear-gradient(145deg,#3d3d3d,#2a2a2a);display:flex;align-items:center;justify-content:center;padding:.75rem;font-size:.9rem;color:#ffffffe6;text-align:center;border-radius:6px}.card-disc-wrap{position:absolute;top:50%;left:var(--disc-start);transform:translate(-50%,-50%);z-index:0;--disc-start: 70px;--disc-end: 160px;animation:discSlideOut .5s cubic-bezier(.22,1,.36,1) .35s forwards}@keyframes discSlideOut{0%{left:var(--disc-start)}to{left:var(--disc-end)}}.vinyl-disc{flex-shrink:0;width:140px;height:140px;border-radius:50%;background:radial-gradient(circle at 50% 50%,#e8e0d0 0% 12%,#1a1a1a 12.5% 99%);position:relative;box-shadow:0 4px 20px #0006,inset 0 0 0 1px #ffffff0d}.vinyl-disc-grooves{position:absolute;inset:14%;border-radius:50%;background:repeating-radial-gradient(circle at 50% 50%,transparent 0px,transparent 2px,rgba(0,0,0,.15) 2px,rgba(0,0,0,.15) 3px);pointer-events:none}.vinyl-disc-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:28%;height:28%;border-radius:50%;background:#e8e0d0}.vinyl-disc-label:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:22%;height:22%;border-radius:50%;background:#1a1a1a}.card-heading{padding:1rem 1.5rem .25rem;text-align:center}.card-heading-album{margin:0;font-size:1.5rem;font-weight:800;color:var(--heading-album);line-height:1.15;letter-spacing:-.01em;transition:color .3s}.card-heading-artist{margin:.2rem 0 0;font-size:1rem;font-weight:400;color:var(--heading-artist);transition:color .3s}.card-ficha{margin:1.25rem 1.5rem;padding:1.25rem 1.5rem;border-radius:6px;display:grid;grid-template-columns:1fr 1fr;gap:1.25rem 2rem}.card-paper{background-color:var(--paper-bg);background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E"),var(--paper-gradient);box-shadow:var(--paper-shadow);border:1px solid var(--paper-border);transition:background-color .3s,border-color .3s}.ficha-column{display:flex;flex-direction:column;gap:.6rem}.ficha-column-left{grid-column:1}.ficha-column-right{grid-column:2}.ficha-field{display:flex;flex-direction:column;gap:.15rem}.ficha-field-tags{grid-column:1 / -1;margin-top:.25rem}.ficha-label{font-size:.7rem;font-weight:600;color:var(--ficha-label);letter-spacing:.04em;transition:color .3s}.ficha-value{font-size:.9rem;color:var(--ficha-value);min-height:1.4em;border-bottom:1px solid var(--ficha-line);transition:color .3s,border-color .3s}.ficha-collection-stamp{grid-column:1 / -1;display:flex;align-items:center;gap:6px;font-family:Space Mono,Courier New,monospace;font-size:.72rem;font-weight:400;color:var(--ficha-label);margin-top:.4rem;opacity:.8}.ficha-tags{display:flex;flex-wrap:wrap;gap:.35rem;padding-top:.25rem}.ficha-tag{font-size:.7rem;font-weight:600;letter-spacing:.03em;padding:.2rem .55rem;border-radius:999px;background:transparent;color:var(--ficha-label);border:1px solid var(--ficha-line)}.card-tracks{padding:0 1.5rem 1.5rem}.card-tracks-title{font-size:1rem;font-weight:600;color:var(--tracks-title);margin:0 0 .75rem;transition:color .3s}.card-tracks-list{margin:0rem;padding-left:.5rem;list-style:none}.card-tracks-item{display:flex;align-items:baseline;gap:.4rem;margin-bottom:.35rem;font-size:.95rem;color:var(--tracks-item);transition:color .3s}.card-tracks-note{font-size:1.2rem;color:var(--tracks-title);opacity:.5;flex-shrink:0}.card-tracks-title-track{font-style:italic}.card-streaming{display:flex;justify-content:center;gap:.5rem;padding:.5rem 1.25rem 1.25rem}.card-streaming-link{position:relative;display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;color:var(--streaming-icon);text-decoration:none;transition:color .2s,transform .2s}.card-streaming-link svg{width:22px;height:22px}.card-streaming-link:hover{transform:scale(1.18)}.card-streaming-link--spotify:hover{color:#1db954}.card-streaming-link--tidal:hover{color:var(--tidal-hover)}.card-streaming-link--youtube:hover{color:red}.streaming-tooltip{position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:#000000bf;color:#fff;font-size:.68rem;white-space:nowrap;padding:3px 8px;border-radius:4px;pointer-events:none;opacity:0;transition:opacity .15s}.card-streaming-link:hover .streaming-tooltip{opacity:1}.card-streaming-link:last-child .streaming-tooltip{left:auto;right:0;transform:none}@media(max-width:640px){.vinyl-tooltip{display:none}.layout{grid-template-columns:1fr}.sidebar{position:static;height:auto;padding:2rem 1.5rem 1.5rem;border-right:none;border-bottom:1px solid var(--sidebar-border);justify-content:flex-start}.shelf-title{font-size:1.5rem}.sidebar-links{flex-direction:row;flex-wrap:wrap}.site-footer{display:none}.mobile-theme-toggle{display:flex!important}.app>.mobile-footer{display:flex!important;flex-direction:column;gap:.5rem;padding:1rem 1.5rem 1.5rem;background:var(--sidebar-bg);border-top:1px solid var(--sidebar-border)}.shelf-page{padding:2rem 1.25rem 4rem}.shelf-scroll-hint{left:50%}.shelf-container{gap:1rem}.shelf-slots{gap:0rem}.vinyl{max-width:160px}.shelf-plank-top{height:12px}.shelf-plank-face{height:20px}.card-top-frame{width:190px;height:130px}.card-cover-wrap{width:130px;height:130px}.card-disc-wrap{--disc-start: 55px;--disc-end: 130px}.card-disc-wrap .vinyl-disc{width:110px;height:110px}.card-ficha{grid-template-columns:1fr}.ficha-column-right{grid-column:1}}[data-theme=dark] .shelf-slots{position:relative}[data-theme=dark] .shelf-slots:after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 55% 110% at 50% 108%,rgba(255,148,38,.18) 0%,rgba(255,120,20,.08) 45%,transparent 65%);pointer-events:none;z-index:0}[data-theme=dark] .shelf-plank:before{content:"";position:absolute;bottom:100%;left:0;right:0;height:100px;background:radial-gradient(ellipse 50% 100% at 50% 100%,rgba(255,170,80,.25) 0%,rgba(220,150,60,.09) 45%,transparent 65%);pointer-events:none}[data-theme=dark] .shelf-plank-top{background:linear-gradient(to bottom,#c49260,#a87844);box-shadow:inset 0 1px #fff3}[data-theme=dark] .shelf-plank-face{background:linear-gradient(to bottom,#8a5e34,#74482a);box-shadow:0 8px 16px #0006}[data-theme=dark] .vinyl-disc{background:radial-gradient(circle at 50% 50%,#e8e0d0 0% 12%,#3a3a3a 12.5% 99%);box-shadow:0 4px 20px #0009,inset 0 0 0 1px #ffffff14}.admin-root{min-height:100vh;display:flex;flex-direction:column;background:#f3f4f6;color:#111827;font-family:system-ui,-apple-system,sans-serif;font-size:.9375rem;line-height:1.5}.admin-header{display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;height:56px;background:#fff;border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:50;gap:1rem}.admin-header__left{display:flex;align-items:center;gap:.6rem}.admin-header__logo{font-weight:700;font-size:1rem;letter-spacing:-.02em;color:#111827}.admin-header__badge{background:#111827;color:#fff;font-size:.65rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:2px 7px;border-radius:4px}.admin-header__nav{display:flex;align-items:center;gap:.5rem}.admin-notification{background:#d1fae5;color:#065f46;border-bottom:1px solid #a7f3d0;padding:.6rem 1.5rem;font-size:.875rem;font-weight:500}.admin-main{flex:1;padding:1.5rem;max-width:900px;width:100%;margin:0 auto}.admin-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;gap:1rem}.admin-toolbar__title{font-size:1.375rem;font-weight:700;letter-spacing:-.02em;margin:0;color:#111827}.admin-toolbar__count{font-weight:400;color:#6b7280;font-size:1rem}.admin-list{display:flex;flex-direction:column;gap:.5rem}.admin-list__empty{color:#6b7280;padding:2rem 0;text-align:center}.admin-list__row{display:flex;align-items:center;gap:1rem;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:.75rem 1rem;transition:box-shadow .15s}.admin-list__row:hover{box-shadow:0 2px 8px #00000012}.admin-thumb{width:48px;height:48px;border-radius:4px;object-fit:cover;flex-shrink:0;background:#e5e7eb}.admin-thumb--placeholder{background:linear-gradient(145deg,#3d3d3d,#2a2a2a)}.admin-list__info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.1rem}.admin-list__album{font-weight:600;font-size:.9rem;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-list__artist{font-size:.8rem;color:#6b7280;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-list__meta{display:flex;flex-direction:column;align-items:flex-end;gap:.1rem;flex-shrink:0}.admin-list__year{font-size:.85rem;color:#374151;font-weight:500}.admin-list__genre{font-size:.75rem;color:#9ca3af}.admin-list__actions{display:flex;gap:.4rem;flex-shrink:0}.admin-btn{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;border:none;border-radius:6px;font-family:inherit;font-size:.875rem;font-weight:500;cursor:pointer;padding:.5rem 1rem;text-decoration:none;line-height:1;transition:background .15s,color .15s,box-shadow .15s;white-space:nowrap}.admin-btn--primary{background:#111827;color:#fff}.admin-btn--primary:hover{background:#1f2937}.admin-btn--secondary{background:#f3f4f6;color:#374151;border:1px solid #d1d5db}.admin-btn--secondary:hover{background:#e5e7eb}.admin-btn--danger{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.admin-btn--danger:hover{background:#fecaca}.admin-btn--ghost{background:transparent;color:#6b7280;border:1px solid #e5e7eb}.admin-btn--ghost:hover{background:#f9fafb;color:#111827}.admin-btn--sm{font-size:.8rem;padding:.35rem .7rem}.admin-form{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:1.75rem;display:flex;flex-direction:column;gap:1.5rem}.admin-form__title{font-size:1.25rem;font-weight:700;letter-spacing:-.02em;margin:0;color:#111827}.admin-form__fieldset{border:1px solid #e5e7eb;border-radius:8px;padding:1rem 1.25rem 1.25rem;margin:0;display:flex;flex-direction:column;gap:1rem}.admin-form__legend{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#6b7280;padding:0 .25rem}.admin-form__grid{display:grid;grid-template-columns:1fr 1fr;gap:.875rem 1.25rem}.admin-form__field{display:flex;flex-direction:column;gap:.3rem}.admin-form__field--full{grid-column:1 / -1}.admin-form__label{font-size:.78rem;font-weight:600;color:#374151}.admin-form__input{font-family:inherit;font-size:.875rem;color:#111827;background:#f9fafb;border:1px solid #d1d5db;border-radius:6px;padding:.45rem .65rem;outline:none;transition:border-color .15s,box-shadow .15s;width:100%;box-sizing:border-box}.admin-form__input:focus{border-color:#6b7280;box-shadow:0 0 0 3px #6b728026;background:#fff}.admin-form__textarea{resize:vertical;min-height:72px}.admin-form__preview{margin-top:.25rem}.admin-form__preview-img{width:80px;height:80px;object-fit:cover;border-radius:6px;border:1px solid #e5e7eb}.admin-form__actions{display:flex;gap:.75rem;padding-top:.25rem}.admin-collection-check{display:flex;align-items:center;gap:.5rem;margin-top:.75rem;font-size:.875rem;color:#374151;cursor:pointer;width:fit-content}.admin-collection-check input[type=checkbox]{width:1rem;height:1rem;accent-color:#374151;cursor:pointer;flex-shrink:0}.admin-tracks{display:flex;flex-direction:column;gap:.6rem}.admin-tracks__header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.admin-tracks__empty{font-size:.85rem;color:#9ca3af;margin:0}.admin-tracks__row{display:flex;align-items:center;gap:.5rem}.admin-tracks__position{width:64px;flex-shrink:0;text-align:center}.admin-tracks__title{flex:1}.admin-tags{display:flex;flex-direction:column;gap:.5rem}.admin-tags__pills{display:flex;flex-wrap:wrap;gap:.35rem}.admin-tag{display:inline-flex;align-items:center;gap:.3rem;font-size:.78rem;font-weight:600;padding:.2rem .5rem .2rem .65rem;border-radius:999px;background:#e5e7eb;color:#374151}.admin-tag__remove{display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;font-size:.65rem;color:#6b7280;padding:0;line-height:1}.admin-tag__remove:hover{color:#111827}@media(max-width:600px){.admin-header{padding:0 1rem}.admin-main{padding:1rem}.admin-form{padding:1.25rem}.admin-form__grid{grid-template-columns:1fr}.admin-list__meta{display:none}.admin-toolbar{flex-direction:column;align-items:flex-start}}
