@import url(https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@300;400;500;600;700&display=swap);*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.17 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb;box-sizing:border-box}:after,:before{--tw-content:""}:host,html{-webkit-text-size-adjust:100%;font-feature-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-variation-settings:normal;line-height:1.5;tab-size:4}body{line-height:inherit}hr{border-top-width:1px;color:inherit;height:0}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;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-feature-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em;font-variation-settings:normal}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:initial}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}button,input,optgroup,select,textarea{font-feature-settings:inherit;color:inherit;font-family:inherit;font-size:100%;font-variation-settings:inherit;font-weight:inherit;letter-spacing:inherit;line-height:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:initial;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:initial}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{color:#9ca3af;opacity:1}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}[hidden]:where(:not([hidden=until-found])){display:none}.mb-10{margin-bottom:2.5rem}.mt-12{margin-top:3rem}.block{display:block}.flex{display:flex}.grid{display:grid}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.flex-wrap{flex-wrap:wrap}.text-wrap{text-wrap:wrap}.border{border-width:1px}.text-center{text-align:center}.uppercase{text-transform:uppercase}.underline{-webkit-text-decoration-line:underline;text-decoration-line:underline}.outline{outline-style:solid}.blur{--tw-blur:blur(8px)}.blur,.drop-shadow{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)}.drop-shadow{--tw-drop-shadow:drop-shadow(0 1px 2px #0000001a) drop-shadow(0 1px 1px #0000000f)}.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)}.transition{transition-duration:.15s;transition-property:color,background-color,border-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-text-decoration-color,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-text-decoration-color,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box;margin:0;padding:0}body{background-color:#0a0a0a;color:#e8e8e8;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px;line-height:1.5;overflow-x:hidden}.App{background:#0a0a0a;min-height:100vh;padding-bottom:80px;position:relative}.app-header{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0a0a0af2;border-bottom:1px solid #1a1a1a;padding:1rem 0;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header-content{align-items:center;display:flex;gap:1rem;justify-content:space-between;margin:0 auto;max-width:1400px;padding:0 1.5rem}.header-left{flex:1 1}.home-btn{background:none;border:none;cursor:pointer;padding:0;text-align:left;transition:all .2s ease}.home-btn:hover{opacity:.8}.app-title{color:#fff;font-family:Inter,sans-serif;font-size:1.5rem;font-weight:600;letter-spacing:-.02em;margin-bottom:.25rem}.app-subtitle{color:#888;font-size:.75rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase}.header-actions{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.health-summary{align-items:center;background:#ffffff0d;border:1px solid #2a2a2a;border-radius:6px;display:flex;gap:.5rem;padding:.5rem .75rem}.health-text{color:#aaa;font-family:JetBrains Mono,monospace;font-size:.75rem;font-weight:400}.health-check-btn{background:#0000;border:none;border-radius:4px;color:#aaa;cursor:pointer;font-size:.8rem;padding:.25rem;transition:all .2s ease}.health-check-btn:hover{background:#ffffff1a;color:#fff}.stream-error-banner{animation:slideDown .3s ease;background:#dc26261a;border:1px solid #dc262633;border-radius:8px;margin:1rem auto;max-width:1200px;padding:1rem}.error-content{align-items:center;color:#fca5a5;display:flex;gap:1rem}.error-icon{font-size:1rem}.error-text{flex:1 1;font-family:Inter,sans-serif;font-size:.8rem}.error-close-btn{align-items:center;background:#dc262633;border:1px solid #dc26264d;border-radius:4px;color:#fca5a5;cursor:pointer;display:flex;font-size:.7rem;height:24px;justify-content:center;transition:all .2s ease;width:24px}.error-close-btn:hover{background:#ff00004d;transform:scale(1.1)}.login-btn,.logout-btn{background:#fff;border:none;border-radius:6px;color:#000;cursor:pointer;font-family:Inter,sans-serif;font-size:.75rem;font-weight:500;letter-spacing:.05em;padding:.5rem 1rem;text-transform:uppercase;transition:all .2s ease}.login-btn:hover,.logout-btn:hover{background:#f0f0f0}.user-menu{align-items:center;color:#aaa;display:flex;font-size:.8rem;gap:1rem}.search-section{margin:1.5rem auto;max-width:1200px;padding:0 1.5rem}.search-input-wrapper{align-items:center;display:flex;position:relative}.search-input{background:#ffffff0d;border:1px solid #2a2a2a;border-radius:8px;color:#e8e8e8;font-family:Inter,sans-serif;font-size:.9rem;padding:.75rem 3rem .75rem 1rem;transition:all .2s ease;width:100%}.search-input:focus{background:#ffffff14;border-color:#555;outline:none}.search-input::placeholder{color:#666}.search-clear-btn{align-items:center;background:#ffffff1a;border:none;border-radius:4px;color:#aaa;cursor:pointer;display:flex;font-size:.7rem;height:24px;justify-content:center;position:absolute;right:.75rem;transition:all .2s ease;width:24px}.search-clear-btn:hover{background:#fff3;color:#fff}.nav-tabs{display:flex;gap:0;margin:1.5rem auto;max-width:1200px;padding:0 1.5rem}.tab{background:#0000;border:1px solid #2a2a2a;border-right:none;color:#888;cursor:pointer;flex:1 1;font-family:Inter,sans-serif;font-size:.8rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s ease}.tab:first-child{border-radius:6px 0 0 6px}.tab:last-child{border-radius:0 6px 6px 0;border-right:1px solid #2a2a2a}.tab:hover{background:#ffffff0d;color:#fff}.tab.active{background:#fff;border-color:#fff;color:#000;font-weight:600}.stations-container{margin:0 auto;max-width:1400px;padding:0 1.5rem}.stations-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));margin-bottom:2rem}.station-card{background:#ffffff08;border:1px solid #ffffff1a;border-radius:12px;cursor:pointer;overflow:hidden;position:relative;transition:all .3s ease}.station-card:hover{background:#ffffff0d;border-color:#fff3;box-shadow:0 8px 25px #0000004d;transform:translateY(-2px)}.station-card.current{background:#4ecdc41a;border-color:#4ecdc4}.station-card.playing{animation:pulse 2s infinite;background:#4ecdc426;border-color:#4ecdc4}.station-card.offline{background:#ff6b6b1a;border-color:#ff6b6b4d;opacity:.6}.card-play-button-overlay{align-items:center;background:linear-gradient(45deg,#ff6b6b,#4ecdc4);border-radius:50%;cursor:pointer;display:flex;height:60px;justify-content:center;left:50%;opacity:0;position:absolute;top:50%;transform:translate(-50%,-50%);transition:all .3s ease;width:60px;z-index:2}.station-card.current .card-play-button-overlay,.station-card.playing .card-play-button-overlay,.station-card:hover .card-play-button-overlay{opacity:1}.play-icon{align-items:center;color:#fff;display:flex;font-size:24px;justify-content:center}.card-content{padding:20px;position:relative;z-index:1}.card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:12px}.card-call-letters{color:#4ecdc4;font-size:1.8rem;font-weight:700;margin:0;text-shadow:0 2px 4px #00000080}.card-reliability{background:#4ecdc433;border-radius:12px;color:#4ecdc4;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:4px 8px;text-transform:uppercase}.card-body{margin-bottom:15px}.card-station-name{color:#fff;font-size:1rem;font-weight:600;margin:0 0 4px}.card-station-location{color:#ffffffb3;font-size:.875rem;margin:0 0 8px}.card-footer{align-items:center;display:flex;justify-content:space-between}.card-genres{display:flex;flex-wrap:wrap;gap:6px}.genre-tag{background:#ffffff1a;border-radius:12px;color:#fffc;font-size:.75rem;letter-spacing:.5px;padding:4px 8px;text-transform:uppercase}.card-actions{display:flex;gap:8px}.icon-button{align-items:center;background:#ffffff1a;border:none;border-radius:50%;color:#ffffffb3;cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s ease;width:36px}.icon-button:hover{background:#fff3;color:#fff;transform:scale(1.1)}.icon-button:disabled{cursor:not-allowed;opacity:.5;transform:none}.player-bar{align-items:center;animation:slideUp .3s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#000000e6,#1a1a2ee6);border-top:1px solid #ffffff1a;bottom:0;display:flex;justify-content:space-between;left:0;padding:12px 20px;position:fixed;right:0;z-index:1000}.player-station-info{align-items:center;display:flex;flex:1 1;gap:12px;min-width:0}.player-station-info span{color:#ffffffb3;font-size:.875rem;letter-spacing:.5px;text-transform:uppercase}.player-station-info strong{color:#4ecdc4;font-size:1rem;font-weight:700}.player-controls{align-items:center;display:flex;gap:15px}.player-controls input[type=range]{background:#fff3;border-radius:2px;cursor:pointer;height:4px;outline:none;width:100px}.player-controls input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#4ecdc4;border-radius:50%;cursor:pointer;height:16px;width:16px}.stop-button{background:#ff6b6bcc;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;letter-spacing:.5px;padding:8px 12px;text-transform:uppercase;transition:all .2s ease}.stop-button:hover{background:#ff6b6b;transform:scale(1.05)}.modal-overlay{align-items:center;animation:fadeIn .3s ease-out;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:2000}.modal-content{animation:slideIn .3s ease-out;background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid #ffffff1a;border-radius:15px;box-shadow:0 20px 40px #0000004d;max-width:400px;padding:30px;position:relative;width:90%}.modal-close{background:none;border:none;color:#fff9;cursor:pointer;font-size:24px;position:absolute;right:15px;top:15px;transition:color .2s ease}.modal-close:hover{color:#fff}.modal-content h2{color:#4ecdc4;font-size:1.5rem;font-weight:700;margin:0 0 20px;text-align:center}.modal-content form{display:flex;flex-direction:column;gap:15px}.modal-content input{background:#ffffff1a;border:1px solid #fff3;border-radius:8px;color:#fff;font-size:1rem;outline:none;padding:12px 15px;transition:all .2s ease}.modal-content input:focus{background:#ffffff26;border-color:#4ecdc4}.modal-content input::placeholder{color:#ffffff80}.submit-button{background:linear-gradient(45deg,#ff6b6b,#4ecdc4);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;letter-spacing:.5px;padding:12px 20px;text-transform:uppercase;transition:all .2s ease}.submit-button:hover{box-shadow:0 5px 15px #0000004d;transform:translateY(-2px)}.submit-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.error-message{color:#ff6b6b;margin:0}.error-message,.link-button{font-size:.875rem;text-align:center}.link-button{background:none;border:none;color:#4ecdc4;cursor:pointer;margin-top:15px;text-decoration:underline;transition:color .2s ease}.link-button:hover{color:#fff}.app-loading{align-items:center;background:#0a0a0a;display:flex;justify-content:center;min-height:100vh}.loading-content{text-align:center}.loading-content h1{color:#fff;font-family:Inter,sans-serif;font-size:2rem;font-weight:600;margin-bottom:1rem}.loading-spinner{animation:spin 2s linear infinite;font-size:2rem}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.app-layout{min-height:100vh;padding-bottom:80px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}
/*# sourceMappingURL=main.c36c0d3f.css.map*/