.login-title{font-size:2.2rem;font-weight:700;margin-bottom:0;background:linear-gradient(135deg,#1db954,#1ed760 60%,#fff);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent!important;text-shadow:0 0 16px #1db954,0 2px 8px rgba(29,185,84,.08);letter-spacing:-1px;text-align:center}.login-centered{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;width:100%;min-width:100%;padding:0;margin:0}@supports (-webkit-touch-callout: none){.login-centered{width:100%;min-width:100%;max-width:100%;overflow-x:hidden}.login-container{-webkit-transform:translate3d(0,0,0);transform:translateZ(0);background:#000c;-webkit-background-clip:padding-box;background-clip:padding-box}.login-modal .spotify-button{-webkit-transform:translate3d(0,0,0);transform:translateZ(0);background:-webkit-linear-gradient(45deg,var(--primary-color),var(--primary-hover));background:linear-gradient(45deg,var(--primary-color),var(--primary-hover))}}@property --angle{syntax: "<angle>"; initial-value: 0deg; inherits: false;}.loading-bg-conic{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;z-index:1;border-radius:var(--border-radius-xl);pointer-events:none;background:inherit;overflow:visible}.loading-bg-conic:before,.loading-bg-conic:after{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border-radius:calc(var(--border-radius-xl) + 2px)!important;z-index:1}.loading-bg-conic:before{background:conic-gradient(from var(--angle),#1DB954 0deg 120deg,transparent 120deg 360deg);filter:blur(24px);opacity:.9;z-index:1;transition:background .3s}.loading-bg-conic:after{background:conic-gradient(from var(--angle),#1DB954 0deg 120deg,transparent 120deg 360deg);opacity:.8;z-index:2;transition:background .3s;filter:blur(1px)}.loading-bg-conic-inner{display:none}@keyframes spinAngle{0%{--angle: 0deg}to{--angle: 360deg}}.loading-bg-conic,.loading-bg-conic:before,.loading-bg-conic:after{animation:spinAngle 3s linear infinite}.loading-modal-wrapper{position:relative;width:clamp(220px,40vw,340px);aspect-ratio:1 / 1;display:flex;align-items:center;justify-content:center}.loading-modal{position:relative;z-index:3;width:98%;height:98%;background:#000!important;border-radius:var(--border-radius-xl)!important;opacity:1!important;box-sizing:border-box;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 12px 48px #00000073,0 1.5px 8px #1db95414;overflow:hidden;padding:clamp(.7rem,2vw,1.2rem);overflow-y:auto;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.loading-modal:before{display:none}.loading-title{font-size:clamp(1.1rem,3vw,2.1rem);font-weight:700;color:var(--text-primary);margin-bottom:clamp(.5rem,2vw,1.1rem);background:linear-gradient(135deg,#1db954,#1ed760 60%,#fff);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;text-shadow:0 2px 8px rgba(29,185,84,.08);letter-spacing:-1px;text-align:center}.loading-message{margin-bottom:clamp(.5rem,2vw,1.1rem);font-size:clamp(.9rem,2vw,1.1rem);color:var(--text-secondary);text-align:center;line-height:1.6;font-weight:500;text-shadow:0 1px 2px rgba(0,0,0,.18)}.progress-bar{width:100%;height:3px;background:#ffffff14;border-radius:2px;margin-bottom:clamp(.5rem,1vw,.8rem);overflow:hidden;position:relative;box-shadow:0 2px 8px #1db95414}.progress-fill{height:100%;background:linear-gradient(90deg,#1db954,#1ed760);border-radius:2px;transition:width .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.progress-fill:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),transparent);animation:progressShine 1.5s linear infinite}@keyframes progressShine{0%{transform:translate(-100%)}to{transform:translate(100%)}}.progress-text{font-size:clamp(.85rem,1.5vw,1.05rem);color:var(--text-secondary);margin-top:0;text-align:center;font-weight:600;letter-spacing:.5px;text-shadow:0 1px 2px rgba(0,0,0,.18)}@media (max-width: 600px){.loading-modal-wrapper{width:96vw;max-width:96vw}.loading-modal{width:98%;max-width:none;min-width:100px;min-height:100px}.loading-title{font-size:1.3rem}.loading-message{font-size:1rem}.progress-bar{height:3px}.progress-text{font-size:.95rem}}@supports (-webkit-touch-callout: none){.loading-app-bg{background:-webkit-linear-gradient(135deg,#1DB954 0%,#1ed760 100%);background:linear-gradient(135deg,#1db954,#1ed760);-webkit-transform:translate3d(0,0,0);transform:translateZ(0);-webkit-background-size:100% 100%;background-size:100% 100%;width:100%;min-width:100%;max-width:100%;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);background-attachment:fixed;background-size:cover;background-position:center;background-repeat:no-repeat;width:100vw;height:100vh;min-width:100vw;min-height:100vh;overflow-x:hidden}.loading-center-stack{width:100%;min-width:100%;max-width:100%;overflow-x:hidden;width:100vw;height:100vh;min-width:100vw;min-height:100vh}.loading-modal-wrapper{width:90vw;max-width:90vw}.loading-modal{-webkit-transform:translate3d(0,0,0);transform:translateZ(0);background:#000!important;-webkit-background-clip:padding-box;background-clip:padding-box}}@media screen and (-webkit-min-device-pixel-ratio: 0){.loading-app-bg{background:-webkit-linear-gradient(135deg,#1DB954 0%,#1ed760 100%);background:linear-gradient(135deg,#1db954,#1ed760)}}.loading-app-bg{background:linear-gradient(135deg,#1db954,#1ed760);min-height:100vh;height:100vh;max-height:100vh;width:100%;position:relative;overflow:hidden;display:block;-webkit-overflow-scrolling:touch;-webkit-transform:translateZ(0);transform:translateZ(0);min-width:100%;max-width:100%;background-attachment:fixed;background-size:cover;background-position:center;background-repeat:no-repeat}.loading-center-stack{position:relative;width:100%;height:100vh;min-height:100vh;max-height:100vh;display:flex;align-items:center;justify-content:center;-webkit-overflow-scrolling:touch;min-width:100%;max-width:100%;overflow-x:hidden}.mood-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(2,1fr);gap:var(--spacing-md);width:80%;max-width:1200px;height:50vh;margin:0 auto var(--spacing-xl) auto;align-items:stretch;justify-items:stretch;background:transparent}.device-selector select{width:100%;padding:var(--spacing-md);border-radius:var(--border-radius-md);border:1px solid var(--border-color);background-color:var(--background-lighter);color:var(--text-primary);font-size:var(--font-size-md);cursor:pointer;transition:all var(--transition-speed) ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3e%3cpath d='M7 10l5 5 5-5z'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 1rem center;background-size:1.5rem;position:relative;z-index:3}@supports (-webkit-touch-callout: none){.mood-grid{width:80%;min-width:80%;max-width:1200px;overflow-x:hidden}.device-selector{-webkit-transform:translate3d(0,0,0);transform:translateZ(0)}.device-selector select{-webkit-transform:translate3d(0,0,0);transform:translateZ(0);-webkit-appearance:none;-moz-appearance:none;appearance:none}}.app.failure-centered{min-height:100vh;width:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e1e1e,#2d2d2d)}.failure-content{background:#181818f7;border-radius:24px;box-shadow:0 12px 48px #00000073;padding:40px 32px;max-width:420px;width:100%;text-align:center;display:flex;flex-direction:column;align-items:center;animation:float-in .7s cubic-bezier(.4,0,.2,1) .1s both}.failure-title{font-size:2.2rem;font-weight:700;margin-bottom:1.2rem;background:linear-gradient(135deg,#ff4d4f,#ff7875,#fff);background-clip:text;-webkit-background-clip:text;color:transparent;-webkit-text-fill-color:transparent;text-shadow:0 0 16px #ff4d4f,0 2px 8px rgba(255,77,79,.08);letter-spacing:-1px;text-align:center;animation:float-in .7s cubic-bezier(.4,0,.2,1) .2s both,bounce-smooth 2.2s ease-in-out infinite}.failure-message{color:#fff;margin-bottom:2rem;font-size:1.1rem;text-align:center;animation:float-in .7s cubic-bezier(.4,0,.2,1) .4s both}@supports (-webkit-touch-callout: none){.app.failure-centered{width:100%;min-width:100%;max-width:100%;overflow-x:hidden;-webkit-transform:translate3d(0,0,0);transform:translateZ(0);background:-webkit-linear-gradient(135deg,#1e1e1e,#2d2d2d);background:linear-gradient(135deg,#1e1e1e,#2d2d2d);-webkit-background-size:100% 100%;background-size:100% 100%}.failure-content{-webkit-transform:translate3d(0,0,0);transform:translateZ(0)}}:root{--primary-color: #1DB954;--primary-hover: #1ed760;--primary-dark: #1aa34a;--background-dark: #121212;--background-light: #181818;--background-lighter: #282828;--background-hover: #333333;--text-primary: #ffffff;--text-secondary: #b3b3b3;--text-tertiary: #727272;--border-color: #333;--shadow-color: rgba(0, 0, 0, .3);--transition-speed: .3s;--border-radius-sm: 4px;--border-radius-md: 8px;--border-radius-lg: 16px;--border-radius-xl: 24px;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-md: 1rem;--font-size-lg: 1.25rem;--font-size-xl: 1.5rem;--font-size-2xl: 2rem;--font-size-3xl: 2.5rem}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;margin:0;padding:0;background:linear-gradient(135deg,#1e1e1e,#2d2d2d);color:var(--text-primary);min-height:100vh;width:100vw;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;position:relative;overflow-x:hidden}html{scrollbar-width:none;-ms-overflow-style:none}html::-webkit-scrollbar{display:none}body{scrollbar-width:none;-ms-overflow-style:none}body::-webkit-scrollbar{display:none}*{scrollbar-width:none;-ms-overflow-style:none}*::-webkit-scrollbar{display:none}body:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 20%,rgba(29,185,84,.1) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(29,185,84,.1) 0%,transparent 50%);animation:backgroundPulse 15s ease-in-out infinite alternate;z-index:-1}@keyframes backgroundPulse{0%{transform:scale(1);opacity:.5}to{transform:scale(1.2);opacity:.8}}.container{background-color:var(--background-light);padding:var(--spacing-xl);border-radius:var(--border-radius-lg);box-shadow:0 8px 32px var(--shadow-color);width:90%;max-width:800px;margin:var(--spacing-lg);box-sizing:border-box;text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);position:relative;overflow:hidden;transition:transform .5s cubic-bezier(.4,0,.2,1);background:#181818}.container>*{pointer-events:auto}.container:before{display:none}.container.mood-happy,.container.mood-sad,.container.mood-energetic,.container.mood-calm,.container.mood-mad,.container.mood-romantic,.container.mood-focused,.container.mood-mysterious{background:#181818}.login-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:var(--spacing-xl);background:#000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;overflow:hidden}.login-container:before{display:none}.login-container:after{display:none}.title-container{background:transparent;padding:0;border-radius:var(--border-radius-lg);position:relative;overflow:visible;width:100%;max-width:400px;margin-bottom:var(--spacing-xl);display:flex;justify-content:center;align-items:center}.login-title{font-size:2.2rem;font-weight:700;margin-bottom:0;background:linear-gradient(135deg,#1db954,#1ed760 60%,#fff);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent!important;text-shadow:0 0 16px #1db954,0 2px 8px rgba(29,185,84,.08);letter-spacing:-1px;text-align:center;animation:fadeIn .5s ease-out .2s both,bounce-smooth 2.2s ease-in-out infinite}@keyframes bounce-smooth{0%{transform:translateY(0)}5%{transform:translateY(-1.5px)}10%{transform:translateY(-3px)}15%{transform:translateY(-4px)}20%{transform:translateY(-5px)}25%{transform:translateY(-5.5px)}30%{transform:translateY(-5px)}35%{transform:translateY(-4px)}40%{transform:translateY(-3px)}45%{transform:translateY(-1.5px)}50%{transform:translateY(0)}55%{transform:translateY(-1.5px)}60%{transform:translateY(-3px)}65%{transform:translateY(-4px)}70%{transform:translateY(-5px)}75%{transform:translateY(-5.5px)}80%{transform:translateY(-5px)}85%{transform:translateY(-4px)}90%{transform:translateY(-2px)}95%{transform:translateY(-1px)}to{transform:translateY(0)}}@keyframes float-in{0%{opacity:0;transform:translateY(40px) scale(.96);filter:blur(8px)}30%{opacity:.4;transform:translateY(18px) scale(.98);filter:blur(4px)}60%{opacity:.85;transform:translateY(-6px) scale(1.01);filter:blur(1.5px)}80%{opacity:1;transform:translateY(-2px) scale(1);filter:blur(.5px)}to{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}}.login-container.enhanced{background:#181818;border-radius:var(--border-radius-xl);box-shadow:0 12px 48px #00000073,0 1.5px 8px #1db95414;width:90%;max-width:420px;min-width:320px;min-height:340px;padding:32px;margin:0 auto;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden}.login-modal{background:transparent;box-shadow:none;border-radius:0;width:100%;padding:0;min-width:unset;min-height:unset;margin:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.login-modal:before{content:"";position:absolute;top:-2px;left:-2px;right:-2px;bottom:-2px;background:linear-gradient(45deg,var(--primary-color),var(--primary-hover),var(--primary-color));border-radius:calc(var(--border-radius-lg) + 2px);z-index:-1;animation:pulse 2s ease-in-out infinite}.login-modal .subtitle{font-size:var(--font-size-lg);color:var(--text-secondary);margin-bottom:var(--spacing-md);opacity:.8;animation:float-in .7s cubic-bezier(.4,0,.2,1) .3s both}.login-modal .tagline{color:var(--text-primary);margin-bottom:var(--spacing-lg);animation:float-in .7s cubic-bezier(.4,0,.2,1) .5s both}.login-modal .spotify-button{position:relative;overflow:hidden;z-index:1;transition:all .3s cubic-bezier(.4,0,.2,1);background:linear-gradient(45deg,var(--primary-color),var(--primary-hover));border:none;padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--border-radius-xl);color:#fff;font-size:var(--font-size-md);font-weight:600;cursor:pointer;box-shadow:0 4px 12px #1db9544d;animation:float-in .7s cubic-bezier(.4,0,.2,1) .7s both;margin-top:var(--spacing-md)}.login-modal .spotify-button:hover{background-color:var(--primary-hover);transform:translateY(-2px);box-shadow:0 6px 16px #1db95466}.container.mood-happy{background:linear-gradient(135deg,#ff9f1c,#ffbf69);animation:moodTransition .5s ease-out}.container.mood-sad{background:linear-gradient(135deg,#2c3e50,#3498db);animation:moodTransition .5s ease-out}.container.mood-energetic{background:linear-gradient(135deg,#2ecc71,#27ae60);animation:moodTransition .5s ease-out}.container.mood-calm{background:linear-gradient(135deg,#9b59b6,#8e44ad);animation:moodTransition .5s ease-out}.container.mood-mad{background:linear-gradient(135deg,#e74c3c,#c0392b);animation:moodTransition .5s ease-out}.container.mood-romantic{background:linear-gradient(135deg,#e84393,#fd79a8);animation:moodTransition .5s ease-out}.container.mood-focused{background:linear-gradient(135deg,#0984e3,#74b9ff);animation:moodTransition .5s ease-out}.container.mood-mysterious{background:linear-gradient(135deg,#2d3436,#636e72);animation:moodTransition .5s ease-out}@keyframes moodTransition{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.device-container{background:var(--background-light);padding:var(--spacing-xl);border-radius:var(--border-radius-lg);margin-top:var(--spacing-xl);position:relative;overflow:hidden;transition:all .3s ease;background:#181818}.device-container:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--primary-color),transparent);animation:borderFlow 2s linear infinite}@keyframes borderFlow{0%{transform:translate(-100%)}to{transform:translate(100%)}}.logout-container{margin-top:var(--spacing-xl);padding:var(--spacing-md);border-radius:var(--border-radius-md);background:var(--background-lighter);transition:all .3s ease;background:#181818}.logout-container:hover{background:var(--background-hover);transform:translateY(-2px)}.logout-button{background-color:var(--background-lighter);color:var(--text-secondary);border:none;padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--border-radius-xl);font-size:var(--font-size-md);font-weight:600;cursor:pointer;transition:all var(--transition-speed) cubic-bezier(.4,0,.2,1);text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);box-shadow:0 4px 12px #0003;position:relative;overflow:hidden}.logout-button:hover{background-color:var(--background-hover);color:var(--text-primary)}header{margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--border-color);position:relative}header h1{color:var(--primary-color);margin-bottom:var(--spacing-md);font-size:var(--font-size-3xl);font-weight:700;letter-spacing:-.5px;background:linear-gradient(135deg,var(--primary-color),var(--primary-hover));background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;text-shadow:0 2px 4px rgba(0,0,0,.1)}.spotify-button{background-color:var(--primary-color);color:#fff;border:none;padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--border-radius-xl);font-size:var(--font-size-md);font-weight:600;cursor:pointer;transition:all var(--transition-speed) cubic-bezier(.4,0,.2,1);text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);box-shadow:0 4px 12px #1db9544d;position:relative;overflow:hidden}.spotify-button:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(45deg,#ffffff1a,#fff0);opacity:0;transition:opacity var(--transition-speed) ease}.spotify-button:hover{background-color:var(--primary-hover);transform:translateY(-2px);box-shadow:0 6px 16px #1db95466}.spotify-button:hover:before{opacity:1}.spotify-button:active{transform:translateY(0);box-shadow:0 2px 8px #1db9544d}.spotify-button.logout{background-color:var(--background-lighter);color:#fff;box-shadow:0 4px 12px #0003}.spotify-button.logout:hover{background-color:var(--background-hover);color:var(--text-primary)}.mood-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:var(--spacing-md);margin:var(--spacing-xl) 0;padding:0 var(--spacing-md);pointer-events:auto;z-index:1}.mood-button{padding:var(--spacing-lg);font-size:var(--font-size-md);border-radius:var(--border-radius-md);border:2px solid transparent;cursor:pointer;transition:all var(--transition-speed) cubic-bezier(.4,0,.2,1);font-weight:600;position:relative;overflow:hidden;box-shadow:0 4px 12px #0003;aspect-ratio:1;display:flex;align-items:center;justify-content:center;pointer-events:auto;z-index:1}.mood-button:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(45deg,#ffffff1a,#fff0);opacity:0;transition:opacity var(--transition-speed) ease}.mood-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0000004d}.mood-button:hover:before{opacity:1}.mood-button.selected{border-color:var(--primary-color);transform:scale(1.05);box-shadow:0 6px 16px #0000004d}.mood-button .button-text{position:relative;z-index:1;color:#fff;font-weight:500;text-shadow:0 1px 2px rgba(0,0,0,.2)}.mood-happy{background:linear-gradient(135deg,#ff9f1c,#ffbf69);color:#000}.mood-sad{background:linear-gradient(135deg,#2c3e50,#3498db)}.mood-energetic{background:linear-gradient(135deg,#2ecc71,#27ae60)}.mood-calm{background:linear-gradient(135deg,#9b59b6,#8e44ad)}.mood-mad{background:linear-gradient(135deg,#e74c3c,#c0392b)}.mood-romantic{background:linear-gradient(135deg,#e84393,#fd79a8)}.mood-focused{background:linear-gradient(135deg,#0984e3,#74b9ff)}.mood-mysterious{background:linear-gradient(135deg,#2d3436,#636e72)}.device-selector{margin:var(--spacing-xl) auto;text-align:center;max-width:400px;padding:0 var(--spacing-md);position:relative;z-index:2}.device-selector h3{margin-bottom:var(--spacing-md);color:var(--text-secondary);font-size:var(--font-size-lg);font-weight:500}.device-selector select{width:100%;padding:var(--spacing-md);border-radius:var(--border-radius-md);border:1px solid var(--border-color);background-color:var(--background-lighter);color:var(--text-primary);font-size:var(--font-size-md);cursor:pointer;transition:all var(--transition-speed) ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3e%3cpath d='M7 10l5 5 5-5z'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 1rem center;background-size:1.5rem;position:relative;z-index:3}.device-selector select:hover{background-color:var(--background-hover)}.device-selector select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #1db95433}.message{margin:var(--spacing-lg) auto;padding:var(--spacing-md);border-radius:var(--border-radius-md);background-color:var(--background-lighter);color:var(--text-primary);min-height:20px;text-align:center;max-width:400px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);transition:all var(--transition-speed) ease;display:flex;align-items:center;justify-content:center}.warning-message{color:#f1c40f;background-color:#f1c40f1a;border-color:#f1c40f33}@keyframes pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.8}to{transform:scale(1);opacity:1}}.loading{animation:pulse 1.5s ease-in-out infinite}.auth-loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;width:100vw;background:transparent}.minimal-spinner{width:40px;height:40px;border:3px solid rgba(29,185,84,.1);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 480px){.container{padding:var(--spacing-lg);margin:var(--spacing-md);border-radius:var(--border-radius-md)}header h1{font-size:var(--font-size-2xl)}.mood-buttons{grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm);padding:0}.mood-button{padding:var(--spacing-md);font-size:var(--font-size-sm)}.device-selector{margin:var(--spacing-lg) auto}.device-selector select{padding:var(--spacing-sm);font-size:var(--font-size-sm)}.spotify-button{padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-sm)}.message{margin:var(--spacing-md) auto;padding:var(--spacing-sm);font-size:var(--font-size-sm)}}*{transition:background-color var(--transition-speed) ease,color var(--transition-speed) ease,transform var(--transition-speed) ease,box-shadow var(--transition-speed) ease,border-color var(--transition-speed) ease}:focus{outline:2px solid var(--primary-color);outline-offset:2px}.float-in-delay-1{animation:float-in .7s cubic-bezier(.4,0,.2,1) .15s both!important}.float-in-delay-2{animation:float-in .7s cubic-bezier(.4,0,.2,1) .3s both!important}.float-in-delay-3{animation:float-in .7s cubic-bezier(.4,0,.2,1) .45s both!important}.float-in-delay-4{animation:float-in .7s cubic-bezier(.4,0,.2,1) .6s both!important}.login-container .subtitle{color:#b3b3b3!important}.app{width:100vw;min-height:100vh;height:100%;background:transparent;box-sizing:border-box;padding:0;margin:0;position:relative;border-radius:0!important;box-shadow:none!important}.app-header{width:100%;height:32px;background:transparent;flex-shrink:0}.login-content{display:flex;flex-direction:column;align-items:center;width:100%;flex:1;margin-top:0;justify-content:center}.app main{flex:1 0 auto;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:flex-start}.app footer{flex-shrink:0;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:12px 0 8px;margin:0;min-height:48px;box-sizing:border-box;background:inherit;border:none;box-shadow:none}.mood-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(2,1fr);gap:var(--spacing-md);width:80vw;max-width:1200px;height:50vh;margin:0 auto var(--spacing-xl) auto;align-items:stretch;justify-items:stretch;background:transparent}.app.container{background:none;box-shadow:none;border-radius:0;max-width:none;border:none;padding:0}.app.login-centered{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;width:100vw;min-width:100vw;padding:0;margin:0}.app.login-centered header,.app.login-centered main{width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center}.app.login-centered main{flex:1 0 auto;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;min-height:60vh;padding-top:6vh;padding-bottom:6vh}.login-top-text{margin-bottom:auto;width:100%;display:flex;flex-direction:column;align-items:center}.spotify-button{margin-top:0;margin-bottom:0;align-self:center}.login-content .subtitle{margin-bottom:.5rem}.login-content .tagline{margin-bottom:.7rem}.login-content .spotify-button{margin-top:.5rem}.player-header{width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;margin-top:.5rem;margin-bottom:1.5rem;background:transparent}*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100vh;min-width:100%;min-height:100vh;max-height:100vh;overflow-x:hidden;background:linear-gradient(135deg,#1e1e1e,#2d2d2d);background-attachment:fixed;background-size:cover;background-position:center;background-repeat:no-repeat}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}
