:root{--primary-blue: #2364aa;--light-blue: #f0faff;--dark-navy: #273b4f;--orange: #e18845;--light-orange: #ffb780;--lighter-orange: #fdc397;--cream: #ffefe4;--white: #ffffff;--dark-text: #1a1a1a;--light-text: #f0f0f0;--error-red: #fc766a;--disabled-bg: #f0f0f0;--disabled-text: #999;--border-color: #d0d0d0;--hover-blue: #b1d4e4;--dark-blue: #053750;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--border-radius: 8px;--border-radius-sm: 4px;--border-radius-lg: 10px;--border-standard: 1.5px solid var(--dark-text);--border-thick: 2px solid;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .1);--shadow-md: 0 4px 8px 0 rgba(0, 0, 0, .2), 0 6px 20px 0 rgba(0, 0, 0, .19);--shadow-navbar: 0 2px 8px rgba(0, 0, 0, .15);--transition-fast: .1s ease;--transition-standard: .25s ease;--transition-slow: .3s ease;--font-system: system-ui, Avenir, Helvetica, Arial, sans-serif;--font-helvetica: "Helvetica Neue", Helvetica, Arial, sans-serif;--max-width: 1200px;--player-height: clamp(64px, 8vh, 96px);--modal-z: 25;--navbar-z: 20;--dropdown-z: 25;--player-z: 15}:root{font-family:var(--font-system);line-height:1.5;font-weight:400;color-scheme:light dark;color:var(--white);background-color:var(--primary-blue);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{display:flex;flex-direction:column;flex-grow:1;margin:0;min-height:100dvh;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;background-color:var(--body-background);padding:0;padding-bottom:var(--player-height, 150px)}h1,h2,h3,h4,h5,h6{font-weight:500;line-height:1.2;margin:0 0 .6rem}h1{font-size:3.2em;margin:0}h2{font-size:clamp(1.5rem,4vw,2.4rem);margin-bottom:.8rem}h3{font-size:clamp(1.2rem,3vw,1.8rem);line-height:1.3}h4,h5,h6{font-size:clamp(1rem,2.5vw,1.4rem);line-height:1.4;margin-bottom:.5rem}p{font-size:clamp(.9rem,2vw,1rem);line-height:1.6;margin:0 0 var(--spacing-md) 0}a{color:var(--orange);text-decoration:underline;transition:color var(--transition-standard);cursor:pointer}a:hover{color:var(--lighter-orange)}button{border-radius:var(--border-radius);padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--lighter-orange);color:var(--dark-text);cursor:pointer;box-shadow:var(--shadow-md);border:var(--border-thick) #d89461b4;transition:background-color var(--transition-standard),color var(--transition-standard),border-color var(--transition-standard),transform var(--transition-fast)}button:hover{background-color:var(--lighter-orange);border-color:var(--orange);transform:scale(1.05)}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}button:disabled{opacity:.6;cursor:not-allowed;background-color:var(--disabled-bg);color:var(--disabled-text)}.submit-button{margin:16px}ul,ol{padding-left:var(--spacing-lg);margin:0 0 var(--spacing-md) 0}li{margin-bottom:var(--spacing-sm);line-height:1.6}.container{max-width:var(--max-width);margin:0 auto;padding:0 var(--spacing-md);width:100%}.card{padding:clamp(1rem,4vw,2rem);border-radius:var(--border-radius);border:var(--border-standard);background-color:var(--white);margin-bottom:var(--spacing-md);box-shadow:var(--shadow-sm)}.input-div{display:flex;flex-direction:column;align-items:center}.input-label{font-weight:700;margin-bottom:8px}.error-message{color:var(--error-red)}@media (prefers-color-scheme: light){:root{color:#213547;background-color:var(--white);--text: #213547;--body-background: var(--light-blue);--h-background: var(--white);--h-text: var(--dark-text);--track-background: var(--white);--player-background: var(--dark-navy);--nav-bg: var(--dark-navy)}}@media (prefers-color-scheme: dark){:root{color:var(--light-text);background-color:var(--dark-navy);--text: var(--light-text);--body-background: var(--dark-navy);--h-background: var(--dark-navy);--h-text: var(--dark-text);--track-background: var(--dark-blue);--player-background: #131d28;--nav-bg: #131d28}}.navbar[data-v-a5148945]{background-color:var(--nav-bg);padding:1.25rem 1.5rem;font-family:var(--font-helvetica);display:flex;align-items:center;justify-content:space-between;box-shadow:var(--shadow-navbar);border-bottom:var(--border-thick) var(--orange);position:relative;z-index:var(--navbar-z)}.nav-left[data-v-a5148945]{display:flex;align-items:center;gap:var(--spacing-md)}.nav-right[data-v-a5148945]{display:flex;align-items:center;margin-left:auto}.brand[data-v-a5148945]{font-weight:700;font-size:1.4rem;color:var(--light-orange);letter-spacing:.5px;transition:color var(--transition-slow);text-decoration:none}.brand[data-v-a5148945]:hover{color:var(--lighter-orange)}.navbar-toggle[data-v-a5148945]{background:none;border:none;font-size:1.8rem;color:var(--light-blue);cursor:pointer;display:none;padding:.2rem .5rem;box-shadow:none}.hamburger-icon[data-v-a5148945]:before{content:"☰";font-size:1.8rem}.hamburger-icon[data-v-a5148945]{display:block;width:25px;height:3px;background-color:var(--light-blue);position:relative}.hamburger-icon[data-v-a5148945]:before,.hamburger-icon[data-v-a5148945]:after{content:"";position:absolute;width:25px;height:3px;background-color:var(--light-blue);left:0}.hamburger-icon[data-v-a5148945]:before{top:-8px}.hamburger-icon[data-v-a5148945]:after{top:8px}.nav-links[data-v-a5148945]{display:flex;align-items:center;gap:.75rem}.nav-link[data-v-a5148945]{color:var(--light-blue);font-weight:500;transition:color var(--transition-standard),transform var(--transition-fast);text-decoration:none;letter-spacing:.3px;margin:0 .75rem}.nav-link[data-v-a5148945]:hover,.nav-link[data-v-a5148945]:focus{color:var(--light-orange);transform:scale(1.05)}.nav-link.active[data-v-a5148945]{color:var(--white);font-weight:600;border-bottom:var(--border-thick) var(--light-orange);padding-bottom:.25rem}.user-greeting[data-v-a5148945]{color:var(--light-orange);font-weight:500;margin-right:1.5rem;font-size:.95rem;letter-spacing:.3px}.nav-dropdown[data-v-a5148945]{position:relative}.dropdown-toggle[data-v-a5148945]{background:none!important;border:none!important;color:var(--light-blue);font-weight:500;cursor:pointer;padding:.375rem .75rem;font-size:1rem;text-align:center;transition:color var(--transition-standard)}.dropdown-toggle[data-v-a5148945]:hover,.dropdown-toggle[data-v-a5148945]:focus{color:var(--light-orange);background:none}.dropdown-menu[data-v-a5148945]{position:absolute;top:110%;right:0;background-color:var(--white);border:1px solid var(--border-color);border-radius:var(--border-radius);box-shadow:var(--shadow-md);min-width:140px;display:flex;flex-direction:column;overflow:hidden;z-index:var(--dropdown-z)}.dropdown-item[data-v-a5148945]{background:none;border:none;color:var(--dark-text);font-weight:500;padding:10px 16px;text-align:left;width:100%;cursor:pointer;transition:background-color .2s ease,color .2s ease;font-size:.95rem}.dropdown-item[data-v-a5148945]:hover{background-color:var(--lighter-orange);color:var(--dark-text)}.dropdown-toggle[data-v-a5148945],.dropdown-item[data-v-a5148945]{box-shadow:none!important;outline:none!important}@media (max-width: 768px){.navbar-toggle[data-v-a5148945]{display:block}.nav-links[data-v-a5148945]{position:absolute;top:100%;left:0;right:0;background-color:var(--dark-navy);flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md);display:none}.nav-links.is-open[data-v-a5148945]{display:flex}.nav-link[data-v-a5148945]{margin:0;padding:var(--spacing-sm) 0;width:100%;text-align:center}.nav-right[data-v-a5148945]{margin-left:0}.dropdown-menu[data-v-a5148945]{position:static;box-shadow:none;border:none;background-color:transparent}.dropdown-item[data-v-a5148945]{background-color:var(--dark-navy);color:var(--light-blue);padding:var(--spacing-sm) 0;text-align:center}.dropdown-item[data-v-a5148945]:hover{background-color:var(--light-orange);color:var(--dark-text)}}.app-wrapper[data-v-ba7467cc]{display:flex;flex-direction:column;min-height:100dvh}.user-feed-form[data-v-da83f502]{display:flex;flex-direction:column;align-items:center;padding:24px}.history-box[data-v-e753643f]{position:absolute;top:120%;right:0;width:300px;background:#fff;border:1px solid #ccc;padding:8px;z-index:10;max-height:320px;overflow-y:auto;overflow-x:hidden}ul[data-v-e753643f]{list-style:none;padding:0;margin:0}li[data-v-e753643f]{padding:6px;cursor:pointer;color:#333}div[data-v-e753643f],label[data-v-e753643f]{color:#333}li[data-v-e753643f]:hover{background:#f0f0f0}.controls[data-v-e753643f]{margin-top:16px;display:flex;flex-direction:column;gap:8px}.search-feed-form[data-v-b5210a30]{position:relative;display:flex;flex-direction:column;align-items:center;padding:24px}.input-row[data-v-b5210a30]{display:flex;align-items:center;gap:8px;position:relative}.input-wrap[data-v-b5210a30]{position:relative}.input-wrap input[data-v-b5210a30]{padding-right:36px;box-sizing:border-box}.history-button[data-v-b5210a30]{background:transparent;border:none;cursor:pointer;line-height:1}.clear-button[data-v-b5210a30]{position:absolute;right:12px;top:55%;transform:translateY(-50%);background:transparent;font-size:12px;cursor:pointer;line-height:1}.feed[data-v-76ee8974]{cursor:pointer;text-align:center;background-color:var(--track-background);margin:5px;box-shadow:var(--shadow-md);border-radius:var(--border-radius-sm);transition:transform .2s ease,background-color .2s ease,color .2s ease}.feed[data-v-76ee8974]:hover{background-color:var(--hover-blue);color:var(--dark-blue);transform:scale(1.05);z-index:var(--track-hover-z)}.feed-image[data-v-76ee8974]{width:100px;height:100px;object-fit:cover;border-radius:var(--border-radius);margin-top:10px}.feed-title[data-v-76ee8974]{font-size:16px;font-weight:700;margin:1px;inline-size:125px;overflow-wrap:break-word;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.feeds[data-v-cb86c4dc]{display:flex;flex-wrap:wrap;gap:15px;justify-content:center;max-height:400px;overflow-y:auto;overflow-x:hidden;padding-bottom:10px}.modal[data-v-af6bc939]{position:absolute;top:0;left:0;background-color:#00000040;width:100%;height:100%;display:flex;justify-content:center;align-items:center;z-index:var(--modal-z)}.modal>div[data-v-af6bc939]{background-color:var(--body-background);padding:16px;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);display:flex;flex-direction:column;align-items:center;gap:4px}.button-row[data-v-af6bc939]{display:flex;gap:16px;margin:4px}.player-box[data-v-b03d21ab]{background-color:var(--player-background);padding:clamp(8px,1.5vh,16px);padding-bottom:calc(clamp(8px,1.5vh,16px) + env(safe-area-inset-bottom));right:0;bottom:0;left:0;display:flex;flex-direction:column;flex-shrink:0;align-items:center;justify-content:space-between;z-index:var(--player-z);height:auto;width:100%;min-height:min-content;border-top:2px solid var(--orange)}.player-box p[data-v-b03d21ab]{margin:5px 0;white-space:nowrap;max-width:100ch;color:var(--light-orange);font-size:large;font-weight:700;text-align:center}.player-info-row[data-v-b03d21ab]{display:flex;align-items:center;flex-direction:column;gap:24px;width:100%;max-width:900px}.track-info[data-v-b03d21ab]{display:flex;align-items:center;gap:clamp(8px,2vw,14px);max-width:100%;flex-direction:row}.track-info p[data-v-b03d21ab]{margin:0;color:var(--light-orange);font-size:clamp(.9rem,2.5vw,1.1rem);line-height:1.2;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:left}@media (max-width: 480px){.track-info[data-v-b03d21ab]{gap:8px}.track-info p[data-v-b03d21ab]{font-size:.9rem}}.track-thumbnail[data-v-b03d21ab]{border-radius:var(--border-radius);width:clamp(36px,8vw,50px);height:clamp(36px,8vw,50px);object-fit:cover;flex-shrink:0}.progress-bar[data-v-b03d21ab]{flex:1;color:var(--light-text);margin:8px 20px 0;display:flex;align-items:center;width:100%;max-width:600px}.progress-bar input[type=range][data-v-b03d21ab]{flex:1;min-width:0;max-width:100%;accent-color:var(--light-orange)}.progress-bar span[data-v-b03d21ab]{width:6ch;text-align:center;font-variant-numeric:tabular-nums}.button-row-1[data-v-b03d21ab]{display:flex;flex-direction:row;justify-content:center;align-items:center;gap:16px;margin:1px 2px;transform:scale(.8)}.media-button[data-v-b03d21ab]{padding:0;width:clamp(2.5em,3.5vw,3.25em);height:clamp(2.5em,2vw,3.25em);font-size:clamp(1em,2.2vw,1.1em);line-height:1;display:flex;align-items:center;justify-content:center}.media-button[data-v-b03d21ab]:disabled{background-color:gray;border-color:gray;cursor:not-allowed}.media-button.is-disabled[data-v-b03d21ab]{opacity:.4;filter:grayscale(100%)}.play-button[data-v-b03d21ab]{background-color:var(--cream);border:var(--border-thick) var(--orange);border-radius:var(--border-radius-lg);color:#000;font-size:18px;height:50px;width:100px}.play-icon[data-v-b03d21ab]{width:1.2em;height:1.2em;fill:currentColor}.media-button.play-button[data-v-b03d21ab]{width:clamp(3.5em,5vw,6em);height:clamp(2.5em,2.5vw,3em);font-size:clamp(1.15em,3vw,1.25em)}.play-button[data-v-b03d21ab]:disabled{background-color:gray;border-color:gray}.play-button[data-v-b03d21ab]:hover:enabled,.play-button[data-v-b03d21ab]:active:enabled{background-color:var(--lighter-orange)}.track[data-v-ee783177]{display:flex;align-items:center;gap:.75rem;margin:.5rem 1.5rem;padding:.5rem .75rem;background-color:var(--track-background);border-radius:var(--border-radius-sm);box-shadow:var(--shadow-md);cursor:pointer;transition:transform .2s ease,background-color .2s ease}.track[data-v-ee783177]:hover{background-color:var(--hover-blue);color:var(--dark-blue);transform:scale(1.025)}.track-info[data-v-ee783177]{display:flex;flex-direction:column;min-width:0;width:auto;max-width:50%}.track-title[data-v-ee783177]{font-size:1rem;font-weight:600;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.track:hover .track-title[data-v-ee783177]{text-overflow:clip;white-space:normal}.track-artist[data-v-ee783177]{font-size:.8rem;opacity:.75;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.track:hover .track-artist[data-v-ee783177]{text-overflow:clip;white-space:normal}.track-image[data-v-ee783177]{width:64px;height:64px;flex-shrink:0;border-radius:var(--border-radius-sm);object-fit:cover}.track-description[data-v-ee783177]{flex:1;min-width:0;font-size:.85rem;color:#666;display:-webkit-box;-webkit-box-orient:vertical;line-clamp:3;-webkit-line-clamp:3;overflow:hidden}.track:hover .track-description[data-v-ee783177]{line-clamp:3;-webkit-line-clamp:unset}.user-feed[data-v-beca8a18]{display:flex;flex-direction:column;flex:1;min-height:0;overflow-x:hidden;overflow-y:auto;align-items:stretch;padding-top:5px;padding-bottom:20px;gap:.5rem}.feed-info[data-v-beca8a18]{display:flex;flex-direction:column;align-items:center;min-width:0;gap:.5rem;padding:.5rem;text-align:center}.feed-image[data-v-beca8a18]{width:100%;max-width:200px;aspect-ratio:1 / 1;object-fit:cover;border:2px solid black;border-radius:var(--border-radius-sm);transition:transform .2s ease}.feed-image[data-v-beca8a18]:hover{transform:scale(1.0125)}.feed-title[data-v-beca8a18]{max-width:100%;overflow:hidden;text-overflow:ellipsis;font-size:2rem;font-weight:700;white-space:nowrap}.feed-artist[data-v-beca8a18]{max-width:100%;overflow:hidden;text-overflow:ellipsis;font-size:1.25rem;opacity:.85;white-space:nowrap}.page-layout[data-v-504e19d2]{display:flex;flex-direction:column;flex:1;min-height:0;width:100%;overflow:hidden}.container[data-v-64ef9f45]{display:flex;flex-direction:column;align-items:center;justify-content:center;height:70vh;color:var(--dark-text)}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,var(--dark-navy) 0%,#131d28 100%);padding:var(--spacing-md);overflow-y:auto}.login-card{background:var(--white);padding:var(--spacing-xl);border-radius:var(--border-radius);box-shadow:var(--shadow-md);width:100%;max-width:400px;margin:auto}.login-card h1{text-align:center;margin-bottom:var(--spacing-lg);color:var(--dark-text);font-size:1.8rem}.login-card form{display:flex;flex-direction:column;gap:var(--spacing-md)}.login-card .form-group{display:flex;flex-direction:column}.login-card label{margin-bottom:var(--spacing-sm);color:var(--dark-text);font-weight:500;font-size:.95rem}.login-card input{padding:var(--spacing-sm);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);font-size:1rem;transition:border-color var(--transition-standard)}.login-card input:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 3px #2364aa1a}.login-card input:disabled{background-color:var(--disabled-bg);cursor:not-allowed}.login-card .error-message{background-color:#fc766a1a;color:var(--error-red);padding:var(--spacing-sm);border-radius:var(--border-radius-sm);font-size:.9rem;border-left:4px solid var(--error-red)}.login-card .submit-button{padding:var(--spacing-sm);background:linear-gradient(-45deg,var(--dark-blue) 0%,var(--primary-blue) 70%);color:var(--white);border:none;border-radius:var(--border-radius-sm);font-size:1rem;font-weight:600;cursor:pointer;transition:transform var(--transition-standard),box-shadow var(--transition-standard);margin-top:var(--spacing-sm)}.login-card .submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #2364aa66}.login-card .submit-button:disabled{opacity:.7;cursor:not-allowed}.login-card .signup-link{text-align:center;margin-top:var(--spacing-lg);color:var(--dark-text);font-size:.95rem}.login-card .signup-link a{color:var(--primary-blue);text-decoration:none;font-weight:600;transition:color var(--transition-standard)}.login-card .signup-link a:hover{color:var(--orange);text-decoration:underline}.signup-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,var(--dark-navy) 0%,#131d28 100%);padding:var(--spacing-md);overflow-y:auto}.signup-card{background:var(--white);padding:var(--spacing-xl);border-radius:var(--border-radius);box-shadow:var(--shadow-md);width:100%;max-width:450px;margin:auto}.signup-card h1{text-align:center;margin-bottom:var(--spacing-lg);color:var(--dark-text);font-size:1.8rem}.signup-card form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.signup-card .form-group{display:flex;flex-direction:column}.signup-card label{margin-bottom:var(--spacing-sm);color:var(--dark-text);font-weight:500;font-size:.95rem}.signup-card input{padding:var(--spacing-sm);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);font-size:1rem;transition:border-color var(--transition-standard)}.signup-card input:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 3px #2364aa1a}.signup-card input:disabled{background-color:var(--disabled-bg);cursor:not-allowed}.signup-card .hint{font-size:.8rem;color:var(--disabled-text);margin-top:var(--spacing-xs)}.signup-card .hint.error{color:var(--error-red)}.signup-card .hint.success{color:#3a3}.signup-card .password-requirements{font-size:.85rem;color:var(--disabled-text);margin-top:var(--spacing-sm);display:flex;flex-direction:column;gap:var(--spacing-xs)}.signup-card .password-requirements div{transition:color var(--transition-standard)}.signup-card .password-requirements div.met{color:#3a3;font-weight:500}.signup-card .error-message{background-color:#fc766a1a;color:var(--error-red);padding:var(--spacing-sm);border-radius:var(--border-radius-sm);font-size:.9rem;border-left:4px solid var(--error-red)}.signup-card .success-message{background-color:#3aaa3a1a;color:#3a3;padding:var(--spacing-sm);border-radius:var(--border-radius-sm);font-size:.9rem;border-left:4px solid #3a3}.signup-card .submit-button{padding:var(--spacing-sm);background:linear-gradient(-45deg,var(--dark-blue) 0%,var(--primary-blue) 70%);color:var(--white);border:none;border-radius:var(--border-radius-sm);font-size:1rem;font-weight:600;cursor:pointer;transition:transform var(--transition-standard),box-shadow var(--transition-standard);margin-top:var(--spacing-sm)}.signup-card .submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #2364aa66}.signup-card .submit-button:disabled{opacity:.7;cursor:not-allowed}.signup-card .login-link{text-align:center;margin-top:var(--spacing-lg);color:var(--dark-text);font-size:.95rem}.signup-card .login-link a{color:var(--primary-blue);text-decoration:none;font-weight:600;transition:color var(--transition-standard)}.signup-card .login-link a:hover{color:var(--orange);text-decoration:underline}.auth-flow-actions{display:flex;flex-direction:column;gap:var(--spacing-sm)}.secondary-button{background:transparent;color:var(--primary-blue);border:1px solid var(--primary-blue);box-shadow:none}.secondary-button:hover:not(:disabled){background:#2364aa14;box-shadow:none}.flow-link-row{text-align:center;color:var(--dark-text);font-size:.95rem;margin-top:var(--spacing-sm)}.profile-container{padding:20px;background-color:var(--dark-gray);min-height:100vh;flex:auto}.profile-card{background-color:var(--light-orange);box-shadow:0 2px 4px #0000001a;border-radius:2px;padding:20px;margin:auto;width:min(900px,100%);display:flex;flex-wrap:wrap;gap:16px}.playlist-info{width:100%}.break{flex-basis:100%;height:0;border-bottom:1px solid var(--black)}.profile-card h1{font-size:2rem;margin-bottom:16px;color:var(--white)}.playlist-box{max-height:260px;overflow-y:auto;background:#50505073;border:1px solid var(--white);border-radius:8px;padding:10px;display:flex;flex-direction:column;gap:10px}.empty-playlists{text-align:center;overflow-y:auto;background:#50505073;border:1px solid var(--white);border-radius:8px;padding:10px}.playlist-item{border:1px solid var(--white);border-radius:8px;padding:10px}.loading-state{display:flex;justify-content:center;align-items:center;height:100%}
