*{font-family:inherit}body{margin:0;font-family:Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html{font-size:16px}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}body{background-color:#f0f4f8;margin:0;font-family:Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.app{min-height:100vh;display:flex;flex-direction:column}.app__content{flex:1}@media(max-width:768px){.page-content,.playlist__viewer,.main{padding:1rem}}.navbar{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background-color:#2c2c2c;flex-wrap:wrap}.navbar__logo{display:flex;align-items:center;gap:.5rem}.navbar__logo-img{width:100px;height:80px}.navbar__logo-text{font-size:1.5rem;font-weight:700;color:#fff}.navbar__menu{display:flex;align-items:center;gap:1.5rem;list-style:none;margin:0;padding:0}.navbar__link{color:#fff;text-decoration:none;font-weight:700;transition:color .2s ease,text-decoration-color .2s ease}.navbar__link:hover{color:#6ee7b7;text-decoration:underline}.navbar__spotify-btn{background-color:#1db954;color:#fff;border:none;padding:8px 12px;border-radius:20px;cursor:pointer;font-weight:700;transition:background-color .2s ease}.navbar__spotify-btn:hover{background-color:#1ed760}.navbar__logout-btn{background-color:#555;color:#fff;border:none;padding:8px 12px;border-radius:20px;cursor:pointer;font-weight:700;transition:background-color .2s ease}.navbar__logout-btn:hover{background-color:#777}@media(max-width:768px){.navbar{flex-direction:column;align-items:center;text-align:center}.navbar__logo{margin-bottom:1rem}.navbar__logo-img{width:70px;height:60px}.navbar__logo-text{font-size:1.2rem}.navbar__menu{flex-direction:column;gap:1rem;margin-bottom:1rem;align-items:center}.navbar__spotify-btn,.navbar__logout-btn{width:100%;max-width:250px;text-align:center}}.filter__form{display:flex;flex-direction:column;gap:1rem;align-items:center;margin-bottom:2rem}.filter__row{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;width:100%}.filter__button{background-color:#1db954;color:#fff;padding:.75rem 1.5rem;border-radius:25px;font-weight:700;border:none;cursor:pointer}.playlist__results{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;padding:1rem 0;justify-content:center}.playlist__card{border:1px solid #ddd;border-radius:12px;padding:1rem;background-color:#fff;box-shadow:0 2px 6px #0000000d;transition:transform .2s ease,box-shadow .2s ease;max-width:280px;margin:0 auto}.playlist__card:hover{transform:scale(1.02);box-shadow:0 4px 12px #0000001a}.playlist__card img{border-radius:8px;margin-bottom:.75rem;width:100%;object-fit:cover}.playlist__card h3{margin:.5rem 0;font-size:1.1rem;color:#222}.playlist__card p{margin:.5rem 0;color:#555;font-size:.95rem}.playlist__actions{margin-top:.75rem;display:flex;gap:.5rem;flex-wrap:wrap}.playlist__actions button,.playlist__actions a{padding:.5rem .9rem;font-size:.9rem;border:none;border-radius:6px;cursor:pointer;text-decoration:none;background-color:#007bff;color:#fff;transition:background-color .2s ease}.playlist__actions button:hover,.playlist__actions a:hover{background-color:#0056b3}.saved__message{margin-top:.5rem;color:green;font-weight:700;font-size:.9rem}.home{font-family:Segoe UI,sans-serif;color:#fff;background-image:url(/runningtrail.jpg);background-repeat:no-repeat;background-size:cover;background-position:center center;background-attachment:fixed;min-height:100vh;width:100%;display:flex;flex-direction:column;align-items:center;padding:2rem;box-sizing:border-box}.home__hero{flex:1;text-align:center;padding:2rem;max-width:800px}.home__title{font-size:2.5rem;margin-bottom:1.5rem}.home__hero-buttons{display:flex;justify-content:center;gap:1rem}.home__btn{background-color:#1db954;color:#fff;padding:.75rem 1.5rem;border-radius:25px;text-decoration:none;font-weight:700;border:none;cursor:pointer}.home__btn--secondary{background-color:#333}.home__login-message{margin-top:20px;font-size:1.1rem}.home__playlist{width:100%;max-width:900px;margin-top:2rem;text-align:center}.home__loading{font-size:1.2rem}.home__empty{font-size:1.1rem;opacity:.9}.home__section-title{font-size:1.8rem;margin-bottom:1rem}.home__how{background:#000000b3;padding:2rem;width:100%;max-width:900px;text-align:center;margin-top:3rem;border-radius:10px}.home__how-title{font-size:1.8rem;margin-bottom:1rem}.home__steps{display:flex;flex-direction:column;gap:.5rem}.home__step{font-size:1.1rem}.filter__row{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;margin-bottom:2rem}.filter__group{display:flex;flex-direction:column;flex:1 1 200px;max-width:300px}.filter__group label{margin-bottom:.5rem;font-weight:700;color:#fff}.filter__group select{padding:.75rem;font-size:1rem;border-radius:6px;border:1px solid #ccc}.modal{position:fixed;inset:0;display:flex;justify-content:center;align-items:center;z-index:1000}.modal__overlay{position:absolute;inset:0;background-color:#0009}.modal__container{position:relative;background-color:#111827;padding:24px;border-radius:10px;width:100%;max-width:480px;color:#fff}.modal__title{margin:0 0 16px;font-size:1.4rem;font-weight:600}.modal__form,.modal__content{display:flex;flex-direction:column;gap:12px}.modal__submit-button{padding:10px 14px;border:none;background-color:#10b981;color:#fff;border-radius:6px;font-weight:600;cursor:pointer;transition:background .2s}.modal__submit-button:hover{background-color:#059669}.modal__close-button{position:absolute;right:12px;top:12px;background:none;border:none;color:#fff;font-size:20px;cursor:pointer}.run-history{padding:2rem;max-width:800px;margin:2rem auto}.run-history__entries{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem;margin-top:2rem}form{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}input,select,textarea{padding:.75rem;font-size:1rem;border-radius:8px;border:1px solid #ccc}button{background-color:#1db954;color:#fff;font-weight:700;border:none;padding:.75rem 1.25rem;border-radius:25px;cursor:pointer;transition:background-color .2s ease}button:hover{background-color:#17a44a}.run__entry{background:#fff;color:#333;padding:1.25rem 1.5rem;border-radius:14px;box-shadow:0 8px 20px #00000014;display:flex;flex-direction:column;justify-content:space-between}.run__entry p{margin:.4rem 0;font-size:.95rem}.run__entry button{margin-top:1rem;background-color:#e74c3c;color:#fff;font-size:.85rem;padding:.5rem 1.25rem;border-radius:20px}.run__entry button:hover{background-color:#c0392b}.playlist__viewer{padding:2rem;background:linear-gradient(to bottom,#f0f4f8,#fff);min-height:100vh;padding:1.5rem}.viewer__title{font-size:2rem;margin-bottom:1rem;text-align:center}.filter__bar{display:flex;justify-content:center;margin-bottom:2rem}.loading{text-align:center;font-size:1.2rem}.feedback{margin-top:1rem;text-align:center;font-weight:700;color:#1db954}.suggestions{margin-top:2rem;text-align:center}.suggestions__buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:.5rem}.suggestions__buttons button{padding:.6rem 1rem;background-color:#1db954;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:700;transition:background .3s ease}.suggestions__buttons button:hover{background-color:#17a44a}.track__preview{margin-top:2rem;padding:1rem;background-color:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.track__preview h3{margin-bottom:1rem}.track__preview ul{list-style:none;padding:0}.track__preview li{margin-bottom:1rem;display:flex;flex-direction:column}@media(max-width:768px){.playlist__viewer{padding:1rem}.track__preview{padding:.75rem}.suggestions__buttons{flex-direction:column;gap:.75rem;align-items:center}.suggestions__buttons button{width:100%;max-width:300px}}.profile{padding:1.5rem;max-width:1000px;margin:0 auto}.profile__header{display:flex;gap:1rem;align-items:center}.profile__avatar{width:120px;height:120px;border-radius:10px;object-fit:cover}.profile__info{flex:1}.profile__name{margin:0;font-size:1.8rem}.profile__runs,.profile__saved,.profile__spotify{margin-bottom:2rem}.profile__saved{margin-top:3rem;padding:1rem 2rem;background:linear-gradient(to bottom,#f9f9f9,#fff);border-radius:12px;box-shadow:0 2px 8px #0000000d}.profile__saved h2{font-size:2rem;font-weight:600;margin-bottom:1rem;text-align:center;color:#333}.saved__list{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center}.saved__card{background-color:#fff;border-radius:10px;padding:1rem;width:200px;text-align:center;box-shadow:0 2px 6px #0000001a;transition:transform .3s ease}.saved__card:hover{transform:translateY(-5px)}.saved__card img{width:100%;border-radius:8px;margin-bottom:.5rem}.saved__card h3{font-size:1rem;margin-bottom:.5rem;color:#1db954}.saved__card a{display:inline-block;margin-top:.5rem;padding:.4rem .8rem;background-color:#1db954;color:#fff;border-radius:6px;text-decoration:none;font-size:.9rem;transition:background .3s ease}.saved__card a:hover{background-color:#17a44a}.profile__form .profile__input,.profile__label input{display:block;margin-top:.5rem;padding:8px;width:100%}.profile__btn{padding:8px 12px;border-radius:8px;cursor:pointer;border:none;margin-right:8px;transition:background .3s ease,transform .2s ease}.profile__btn:hover{transform:scale(1.03)}.profile__btn:focus,.profile__input:focus{outline:3px solid rgba(29,185,84,.25);outline-offset:2px}.profile__btn--spotify{background:#1db954;color:#fff}.profile__btn--danger{background:#ff6b6b;color:#fff}.profile__spotify-status{display:inline-block;margin-right:8px;color:#1db954;font-weight:600}.spotify__playlists_list{list-style:none;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.spotify__playlists_item{display:flex;gap:.75rem;align-items:center;background:#fff;padding:.5rem;border-radius:8px}@media(max-width:768px){.saved__list{flex-direction:column;align-items:center}.saved__card{width:90%}}.footer{margin-top:auto;padding:16px 24px;background-color:#030712;color:#9ca3af;display:flex;justify-content:space-between;align-items:center;font-size:.9rem}.footer__text{margin:0}.footer__link{color:#10b981;text-decoration:none;transition:color .2s ease,text-decoration-color .2s ease}.footer__link:hover{color:#6ee7b7;text-decoration:underline}
