.play-bar{position:fixed;bottom:2rem;left:0;right:0;z-index:1000;display:flex;justify-content:center;pointer-events:none;transform:translateY(100%);transition:transform .3s ease-out}.play-bar--visible{transform:translateY(0)}.play-bar__content{pointer-events:auto;display:flex;align-items:center;gap:1rem;padding:.75rem 1.25rem;width:min(650px,94vw);margin:0 2rem;min-height:64px;background:#ffffff0d;border-radius:9999px;border:1px solid rgba(255,255,255,.15);box-shadow:0 18px 45px #0f172a8c;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.play-bar__controls{flex-shrink:0}.play-bar__controls .play-button{width:40px;height:40px;padding:0;border-radius:9999px;background:transparent;border:none;color:#fff9;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:filter .18s ease,opacity .18s ease}.play-bar__controls .play-button:hover:not(:disabled){opacity:.9}.play-bar__controls .play-button:active:not(:disabled){opacity:.8}.play-bar__controls .play-button:disabled{opacity:.6;cursor:not-allowed}.play-bar__controls .play-button .icon{width:55px;height:55px;fill:currentColor}.play-bar__info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.25rem}.play-bar__station-name{font-size:.875rem;font-weight:600;color:#ffffffe6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.play-bar__now-playing{font-size:.75rem;color:#ffffffb3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.play-bar__live-indicator{flex-shrink:0}.live-badge{display:inline-block;padding:.25rem .5rem;font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.4);border-radius:9999px;animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@media (max-width: 640px){.play-bar__content{padding:.75rem 1rem;gap:.75rem;margin:0 1rem}.play-bar__controls .play-button{width:36px;height:36px}.play-bar__station-name{font-size:.8125rem}.play-bar__now-playing{font-size:.6875rem}.live-badge{font-size:.5625rem;padding:.2rem .4rem}}.station-carousel{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:-8rem;position:relative}.station-carousel--single{justify-content:center}.station-carousel__logos{display:flex;align-items:center;justify-content:center;gap:1.5rem;flex:1;overflow-x:auto;overflow-y:visible;scroll-behavior:smooth;scrollbar-width:none;-ms-overflow-style:none;padding:0 1rem;position:relative}.station-carousel__logos::-webkit-scrollbar{display:none}.station-carousel__logo,.station-carousel__logo-wrapper{display:flex;align-items:center;justify-content:center}.station-carousel__logo-button{background:none;border:none;padding:.5rem;opacity:.8;cursor:pointer;transition:transform .2s ease,opacity .2s ease;border-radius:16px;display:flex;align-items:center;justify-content:center;position:relative}.station-carousel__logo-button:hover:not(.station-carousel__logo-button--active){transform:scale(1.1);opacity:1}.station-carousel__logo-button--active{transform:scale(1);position:relative;z-index:1;opacity:1}.station-carousel__logo-button--active img{box-shadow:0 20px 45px #0003;background-color:#fff}.station-carousel__arrow{background:#ffffff0d;border-radius:999px;border:1px solid rgba(255,255,255,.15);box-shadow:0 18px 45px #0f172a8c;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fffc;transition:background-color .2s ease,border-color .2s ease,transform .2s ease;flex-shrink:0;z-index:2}.station-carousel__arrow:hover{background:#ffffff26;border-color:#ffffff4d;transform:scale(1.1)}.station-carousel__arrow:active{transform:scale(.95)}.station-carousel__arrow:focus-visible{outline:2px solid var(--kora-station-colour, #4f46e5);outline-offset:2px}@media (max-width: 768px){.station-carousel{gap:.5rem;padding:0 .5rem;width:100%;max-width:100vw}.station-carousel__arrow{width:32px;height:32px;flex-shrink:0}.station-carousel__arrow svg{width:18px;height:18px}.station-carousel__logos{justify-content:center;gap:.75rem;padding:0 .25rem;flex:1;min-width:0}.station-carousel__logo-button{padding:.25rem}.station-carousel__logo-wrapper{display:flex;align-items:center;justify-content:center}.station-carousel__logo-wrapper img{width:48px!important;height:48px!important}.station-carousel__logo-button--active .station-carousel__logo-wrapper img{width:64px!important;height:64px!important}}:root{color:#fff;background-color:#141414;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;--kora-station-colour: #4f46e5;--kora-body-bg-image: none}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;display:flex;align-items:flex-start;justify-content:center;background-color:#141414;background-image:var(--kora-body-bg-image);background-position:top center;background-repeat:no-repeat;background-size:100%}#root{width:100%;background:linear-gradient(180deg,#14141400 250px,#14141480 350px,#141414 550px)}.kora-card{margin:2rem auto;width:min(800px,94vw);background:#0006;background:linear-gradient(180deg,#0a0a0a66 500px,#0a0a0a00);border-radius:24px;border-top:1px solid rgba(255,255,255,.15);box-shadow:0 20px 45px #0000001f;padding:1rem 1.5rem;display:flex;flex-direction:column;gap:1rem;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.kora-section{display:flex;justify-content:space-between;align-items:center;gap:1rem}.kora-debug{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.85rem;background:#0b172a;color:#f4f6fb;padding:1rem;border-radius:12px;word-break:break-all}.kora-ad-break{color:#b54708}.kora-error{background:#fee4e2;color:#b42318;padding:.75rem 1rem;border-radius:12px;display:flex;align-items:center;justify-content:space-between;gap:1rem}button.kora-primary{border:none;background:var(--kora-station-colour);color:#fff;padding:.75rem 1.5rem;font-size:1rem;border-radius:12px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;box-shadow:0 12px 24px #0f172a40}button.kora-primary:hover{transform:translateY(-1px);filter:brightness(1.05)}button.kora-secondary{border:1px solid rgba(255,255,255,.2);background:#0b172a;color:#fffc;padding:.5rem .75rem;font-size:.875rem;border-radius:10px;cursor:pointer}.location-indicator{position:fixed;top:1rem;right:1rem;z-index:1000;border:1px solid rgba(255,255,255,.2);background:#0b172a;color:#fffc;padding:.5rem .75rem;font-size:.875rem;border-radius:10px;cursor:pointer;transition:background-color .2s ease,border-color .2s ease}.location-indicator:hover:not(.location-indicator--disabled){background:#000c;border-color:#ffffff4d}.location-indicator--disabled{cursor:not-allowed;opacity:.6}.debug-button{position:fixed;bottom:3rem;right:1rem;z-index:1000}.kora-card .play-button{width:110px;height:110px;border-radius:9999px;border:2px solid white;background:var(--kora-station-colour);color:#fff;font-size:2.5rem;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 24px #00000059,inset 0 1px #ffffff59;transition:height .2s ease,width .2s ease,box-shadow .2s ease}.kora-card .play-button:hover:not(:disabled){width:115px;height:115px;cursor:pointer}.kora-card .play-button:disabled{cursor:not-allowed;filter:grayscale(70%)}.kora-card .play-button>.icon{width:60px;height:60px;fill:currentColor;display:block;transition:height .2s ease,width .2s ease}.kora-card .play-button:hover:not(:disabled)>.icon{width:65px;height:65px}.player-shell{padding:6rem 1rem;min-height:100vh}.station-logo-banner{display:flex;justify-content:center;margin-top:-8rem}.station-logo-banner img{width:120px;height:120px;border-radius:9999px;border:4px solid #fff;object-fit:cover;box-shadow:0 20px 45px #0003}.now-playing-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;align-items:stretch}.now-playing-artwork{position:relative;border-radius:16px;overflow:hidden;min-height:320px}.now-playing-artwork img,.now-playing-artwork__placeholder{width:100%;height:100%;object-fit:cover;display:block;aspect-ratio:1 / 1;background:#ffffff1a}.player-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem;gap:.75rem;border-top:1px solid rgba(255,255,255,.15)}.player-overlay .kora-section{flex-direction:column;gap:.75rem;width:100%;color:#fff;justify-content:center;align-items:center;background:transparent;text-align:center}.player-overlay .kora-error{background:#0f172ad9;color:#fff}.now-playing-details{display:flex;flex-direction:column;gap:1rem}.now-playing-details__content{display:flex;flex-direction:column;gap:2rem}.now-playing-context{margin:0;color:#fffc;text-transform:uppercase;letter-spacing:.04em}.now-playing-label{font-size:.8rem;letter-spacing:.04em;text-transform:uppercase;color:#fffc}.now-playing-title{margin:.2rem 0;font-size:2rem;line-height:1.2;font-weight:600}.now-playing-artist{margin:0;color:#fffc;font-size:1rem}.now-playing-programme{padding:1rem;background:#0000001a;border-bottom:1px solid rgb(255,255,255,.1);border-top:1px solid rgb(0,0,0,.3);border-radius:16px;display:flex;flex-direction:row;gap:.75rem;align-items:center}.programme-avatar{width:64px;height:64px;border-radius:16px;object-fit:cover;flex-shrink:0;background:#e2e8f0}.now-playing-programme h3,.now-playing-programme p{margin:0}.now-playing-programme p{color:#ffffff80}.now-playing-times{font-size:.95rem;font-weight:500}.track-lists-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem}.track-list-section{display:flex;flex-direction:column;gap:.75rem}.track-list-title{margin:1.5rem 0 .35rem;color:#fffc;text-transform:uppercase;font-size:.85rem;letter-spacing:.04em}.track-list-empty{margin:0;color:#ffffff80}.track-list-items{display:flex;flex-direction:column;gap:.25rem}.track-list-item{display:flex;align-items:center;gap:.75rem;padding:.5rem 0}.track-list-artwork{width:64px;height:64px;border-radius:16px;object-fit:cover;background:#e2e8f0;flex-shrink:0}.track-list-track{margin:0;font-weight:600}.track-list-artist{margin:0;color:#fffc;font-size:.9rem}@media (max-width: 800px){.now-playing-section,.track-lists-section{grid-template-columns:1fr}}@media (max-width: 640px){.player-shell{padding:5rem .75rem}.kora-card{padding:1.5rem;gap:1.25rem}.player-overlay{padding:1rem}.now-playing-title{font-size:1.5rem}.track-list-item{padding:.35rem 0}}
