.sidebar{position:fixed;top:0;left:-300px;width:300px;height:100vh;background:#fff;box-shadow:2px 0 16px #0000002e;transition:left .3s ease;z-index:1000;overflow-y:auto;display:flex;flex-direction:column}.sidebar.open{left:0}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:999}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:18px 20px;border-bottom:2px solid #f0f0f0;position:sticky;top:0;background:#fff;z-index:1}.sidebar-header h3{font-size:1.1rem;color:#222;margin:0;font-weight:700}.sidebar-close{background:transparent;border:none;font-size:1rem;cursor:pointer;color:#555;max-width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:background .2s;flex-shrink:0;padding:0}.sidebar-close:hover{background:#f0f0f0}.sidebar-content{flex:1;overflow-y:auto;display:flex;flex-direction:column}.sidebar-nav{display:flex;flex-direction:column;padding:8px;flex:0}.sidebar-item{padding:18px 20px;text-decoration:none;color:#333;font-size:1.05rem;font-weight:500;display:flex;align-items:center;gap:12px;cursor:pointer;transition:all .3s;border:none;background:transparent;text-align:left;width:100%;border-bottom:1px solid #f0f0f0}.sidebar-item:hover{background:linear-gradient(90deg,rgba(245,87,108,.1) 0%,transparent 100%);padding-left:28px;color:#f5576c;border-bottom:1px solid #f5576c}.sidebar-item.sidebar-button{background:#1e1e1e;color:#fff;border-radius:10px;border:none;padding:15px 20px;font-size:1rem;box-shadow:0 4px 15px #f5576c33;text-align:center}.display-sidebar-section{padding:14px 16px;border-bottom:1px solid #f0f0f0}.display-sidebar-section-title{font-size:.72rem;text-transform:uppercase;letter-spacing:.6px;color:#999;margin-bottom:10px;font-weight:700}.sidebar-now-playing{display:flex;gap:12px;align-items:flex-start;padding:12px;border-radius:10px;border:2px solid #eee}.sidebar-now-playing.is-playing{border-color:#1db954;background-color:#1db95445}.sidebar-now-playing.is-paused{border-color:#ddd}.sidebar-portada{width:60px;height:60px;border-radius:8px;object-fit:cover;flex-shrink:0}.sidebar-np-info{flex:1;min-width:0}.sidebar-np-label{font-size:.7rem;color:#070707;text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px;display:flex;align-items:center;gap:4px;font-weight:700}.sidebar-now-playing.is-paused .sidebar-np-label{color:#888}.sidebar-np-nombre{font-size:.9rem;font-weight:700;color:#111;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-np-artista{font-size:.78rem;color:#1d1b1b;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:400}.display-sidebar-card{padding:12px 14px;border:2px solid #eee;border-radius:10px}.display-sidebar-card-top{display:flex;justify-content:space-between;align-items:baseline;gap:8px;margin-bottom:5px}.display-sidebar-card-label{font-size:.82rem;font-weight:600;color:#444}.display-sidebar-card-dias{font-size:1.2rem;font-weight:900;color:#111;white-space:nowrap}.display-sidebar-card-nombre{font-size:.85rem;color:#555;margin-bottom:4px;font-weight:500}.display-sidebar-card-fecha{font-size:.76rem;color:#999}.now-playing-dot{display:inline-block;width:7px;height:7px;background:#000;border-radius:50%;animation:blink 1.2s ease-in-out infinite;flex-shrink:0}.sidebar-toggle-btn{display:flex;position:absolute;left:9px;top:35px;transform:translateY(-50%);background:#ffffff53;border:2px solid rgba(255,255,255,.35);color:#000;font-size:1.1rem;width:42px;height:42px;border-radius:8px;cursor:pointer;align-items:center;justify-content:center;transition:background .2s;flex-shrink:0;padding:0}.sidebar-toggle-btn :active{background:#ffffff80;transform:scale(.95)}@media (max-width: 768px){.sidebar{width:280px}}@media (max-width: 480px){.sidebar.open{left:0}}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(135deg,#0e36e6,#0d0170);min-height:100vh;display:flex;flex-direction:column;justify-content:flex-start;align-items:center;padding:10px}.display-container{width:100%;min-height:100vh}.container{width:100%;max-width:900px;margin:10px auto 0;padding:0 10px}#topSaludadores{position:fixed;display:block;bottom:20px;left:20px;background:#fff;color:#667eea;padding:10px 15px;border-radius:20px;font-size:.9rem;box-shadow:0 5px 15px #0003}@media (max-width: 1024px){.feriado-card,.feriado-card2,.feriado-card3,.now-playing-card,#topSaludadores{display:none!important}}@media (max-width: 768px){.saludo{padding:18px;margin-bottom:15px}.saludo-texto{font-size:1.2rem;margin-bottom:12px}.saludo-autor{font-size:1rem}.status{bottom:15px;right:15px;font-size:.85rem;padding:8px 12px}.container{padding:0 5px}#saludos-container{gap:12px}}@media (max-width: 480px){.saludo{padding:12px;margin-bottom:10px;border-radius:10px}.saludo-imagen{max-height:280px;margin-bottom:10px;border-radius:8px}.saludo-texto{font-size:1rem;margin-bottom:8px;line-height:1.3}.saludo-autor{font-size:.9rem}.saludo-ip{font-size:.7rem;margin-top:3px}.saludo-hora{font-size:.7rem;margin-top:6px}.editor-link{padding:10px 20px;font-size:.9rem}.empty-state{padding:40px 15px}.empty-state h2{font-size:1.3rem;margin-bottom:10px}.empty-state p{font-size:.9rem}.status{bottom:10px;right:10px;font-size:.75rem;padding:6px 10px}.container{padding:0 3px;margin-top:5px}#saludos-container{gap:10px}}#saludos-container{display:flex;flex-direction:column;gap:20px}.saludo{background:#fff;padding:30px;border-radius:15px;box-shadow:0 10px 30px #0003}.saludo.nuevo{background:linear-gradient(135deg,#fff,#f5f5f5)}.saludo-imagen{width:100%;max-height:400px;object-fit:contain;border-radius:10px;margin-bottom:15px;display:block}.saludo-texto{font-size:2rem;color:#333;margin-bottom:15px;line-height:1.4;overflow:hidden}.saludo-autor{font-size:1.3rem;color:#000;font-weight:600;text-align:right}.saludo-ip{font-size:.9rem;color:#666;margin-top:5px;text-align:right}.saludo-hora{font-size:.9rem;color:#999;margin-top:10px;text-align:right}.empty-state{text-align:center;color:#fff;padding:60px 20px}.empty-state h2{font-size:2rem;margin-bottom:15px}.editor-link{display:inline-block;margin-top:20px;background:#fff;color:#667eea;padding:12px 30px;border-radius:25px;text-decoration:none;font-weight:600;transition:all .3s}.editor-link:hover{transform:scale(1.05);box-shadow:0 5px 15px #0003}.status{position:fixed;bottom:20px;right:20px;background:#fff;padding:10px 15px;border-radius:20px;font-size:.9rem;color:#667eea;box-shadow:0 5px 15px #0003}.status.animating{animation:pulse .5s}.contenedor-feriados{position:fixed;display:flex;justify-content:flex-start;padding:15px 10px;gap:60px;flex-direction:column;min-height:100vh}.feriado-card{width:280px;background:linear-gradient(135deg,#ff6b6b,#ff8e72);color:#fff;padding:20px;border-radius:15px;font-weight:600;z-index:100}.feriado-card2{width:280px;background:linear-gradient(135deg,#f1f1f1,#dadada);color:#000;padding:20px;border-radius:15px;font-weight:600;z-index:100}.feriado-card3{width:280px;background:linear-gradient(180deg,#f80c00 24%,#fff 38%,#fff 62%,#0142a5 80%);color:#fff;padding:20px;border-radius:15px;font-weight:600;z-index:100;text-shadow:1px 1px 2px rgba(0,0,0,.2)}.feriado-card3 .dias-texto{color:#fff;text-shadow:1px 1px 2px rgba(0,0,0,.3)}.feriado-card3 .dias-faltantes{color:#000;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.feriado-card3 .feriado-nombre{color:#000;text-shadow:1px 1px 3px rgba(0,0,0,.3)}.feriado-card3 .feriado-fecha{color:#000;text-shadow:1px 1px 2px rgba(0,0,0,.2)}.feriado-card3 span{color:#000}.feriado-content{margin-bottom:10px}.dias-faltantes{font-size:3rem;font-weight:900;margin:10px 0;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.dias-texto{font-size:.9rem;opacity:.95;margin-bottom:10px}.feriado-nombre{font-size:1.2rem;margin-bottom:5px;text-shadow:1px 1px 3px rgba(0,0,0,.2)}.feriado-fecha{font-size:.85rem;opacity:.9}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.contenedor-img-now{display:flex;width:100%;justify-content:space-between}.now-playing-card{position:fixed;top:20px;right:20px;width:280px;background:linear-gradient(135deg,#1a1a2e,#16213e);color:#fff;padding:16px;border-radius:15px;box-shadow:0 8px 25px #0006;font-weight:600;z-index:100;display:flex;flex-direction:column;gap:12px;align-items:flex-start;border:2px solid transparent;transition:border-color .4s}.now-playing-card.is-playing{border-color:#1db954;box-shadow:0 8px 25px #1db95440}.now-playing-card.is-paused{border-color:#555}.now-playing-portada{width:72px;height:72px;border-radius:8px;object-fit:cover;flex-shrink:0}.now-playing-info{width:90%;min-width:0;padding:0 10px}.now-playing-label{font-size:.72rem;color:#1db954;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;display:flex;align-items:center;gap:5px}.now-playing-card.is-paused .now-playing-label{color:#888}.now-playing-dot{display:inline-block;width:7px;height:7px;background:#1db954;border-radius:50%;animation:blink 1.2s ease-in-out infinite;flex-shrink:0}@keyframes blink{0%,to{opacity:1}50%{opacity:.2}}.now-playing-nombre{font-size:.9rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#fff}.now-playing-artista{font-size:.78rem;color:#aaa;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:400}.now-playing-barra{margin-top:10px;height:3px;background:#333;border-radius:2px;overflow:hidden}.now-playing-progreso{height:100%;background:#1db954;border-radius:2px}.now-playing-queue{width:100%;padding-top:12px;border-top:1px solid #333;max-height:400px;overflow-y:auto}.queue-title{font-size:.72rem;color:#1db954;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-weight:700}.queue-list{display:flex;flex-direction:column;gap:6px}.queue-item{display:flex;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.05)}.queue-item img{width:40px;height:40px;border-radius:6px;object-fit:cover;margin-right:10px}.queue-item:last-child{border-bottom:none}.queue-item-nombre{font-size:.75rem;font-weight:600;color:#fff;overflow:hidden;text-overflow:ellipsis}.queue-item-artista{font-size:.65rem;color:#999;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.loading-button{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;overflow:hidden}.loading-button:active:not(:disabled){transform:translateY(0)}.loading-button:disabled{opacity:.6;cursor:not-allowed}.loading-button.gif{background:#667eea}.loading-button.cancion{background:#000}.loading-button.is-loading{pointer-events:none}.button-content{display:flex;align-items:center;gap:6px;opacity:1;transition:opacity .2s ease}.loading-button.is-loading .button-content{opacity:0;visibility:hidden}.spinner-wrapper{position:absolute;display:flex;align-items:center;justify-content:center;width:100%;height:100%}.spinner{width:18px;height:18px;display:inline-block}.spinner-default{border:3px solid rgba(255,255,255,.3);border-top:3px solid white;border-radius:50%;animation:spin-default .8s linear infinite}@keyframes spin-default{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinner-gif{width:20px;height:20px;display:flex;align-items:center;justify-content:center;gap:4px}.spinner-gif:before,.spinner-gif:after{content:"";width:4px;height:4px;border-radius:50%;background:#fff;animation:pulse-gif 1.2s ease-in-out infinite}.spinner-gif:before{animation-delay:-.24s}.spinner-gif:after{animation-delay:0s}@keyframes pulse-gif{0%,60%,to{opacity:.3;transform:scale(.8)}30%{opacity:1;transform:scale(1.2)}}.spinner-cancion{width:24px;height:16px;display:flex;align-items:center;justify-content:center;gap:3px}.spinner-cancion:before,.spinner-cancion:after{content:"";width:3px;background:#fff;border-radius:2px;animation:sound-wave 1s ease-in-out infinite}.spinner-cancion:before{height:12px;animation-delay:-.5s}.spinner-cancion:after{height:8px;animation-delay:0s}@keyframes sound-wave{0%,to{height:4px}50%{height:16px}}@media (max-width: 768px){.loading-button{padding:8px 16px;font-size:13px}.spinner{width:16px;height:16px}}.editor-wrapper{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(135deg,#f093fb,#f5576c);min-height:100vh;display:flex;flex-direction:column;justify-content:flex-start;align-items:center}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.editor-card{background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;padding:10px 40px;animation:slideUp .5s ease-out}.container-editor{width:100%;max-width:600px}label{display:block;margin-bottom:8px;color:#333;font-weight:600;font-size:1.1rem}textarea,input[type=text]{width:100%;padding:12px 15px;border:2px solid #f0f0f0;border-radius:10px;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:1rem;transition:all .3s;resize:none}input[type=file]{width:100%;padding:12px 15px;border:2px solid #f0f0f0;border-radius:10px;font-size:1rem;transition:all .3s;cursor:pointer}textarea:focus,input[type=text]:focus,input[type=file]:focus{outline:none;border-color:#f5576c;box-shadow:0 0 0 3px #f5576c1a}textarea{min-height:150px}input[type=text]{height:45px}.form-group textarea::placeholder,.form-group input::placeholder{color:#ccc}.char-counter{font-size:.85rem;color:#999;margin-top:5px;text-align:right}.char-counter.warning{color:#f5576c;font-weight:600}.button-group{display:flex;gap:10px;margin-bottom:20px}.btn-editor{flex:1;padding:15px;border:none;border-radius:10px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s}.btn-guardar{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.btn-guardar:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 25px #f5576c4d}.btn-guardar:active:not(:disabled){transform:translateY(0)}.btn-guardar:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-limpiar{background:#f0f0f0;color:#333}.btn-limpiar:hover{background:#e0e0e0}.btn-ver{background:#667eea;color:#fff}.btn-ver:hover{background:#5568d3}.saludos-guardados{background:#fffffff2;margin-top:30px;padding:20px;border-radius:10px;max-height:300px;overflow-y:auto}.saludos-guardados h3{color:#333;margin-bottom:15px;font-size:1.1rem}.saludo-item{background:#f9f9f9;padding:12px;margin-bottom:10px;border-radius:8px;font-size:.95rem}.saludo-item-texto{color:#333;margin-bottom:5px;font-weight:500}.saludo-item-autor{color:#667eea;font-size:.9rem}.saludo-item-hora{color:#999;font-size:.85rem;margin-top:5px}.scroll-indicator{text-align:center;color:#999;font-size:.9rem;padding-top:10px;border-top:1px solid #f0f0f0}.imagen-preview{margin-top:15px;padding:15px;background:#f9f9f9;border-radius:10px;position:relative}.imagen-preview img{max-width:100%;max-height:300px;border-radius:8px;display:block;margin:0 auto}.btn-limpiar-imagen{background:#ff6b6b;color:#fff;padding:8px 12px;border:none;border-radius:6px;font-size:.9rem;cursor:pointer;margin-top:10px;width:100%;transition:all .3s}.btn-limpiar-imagen:hover{background:#ff5252}.imagen-input-wrapper{position:relative;border:2px dashed #f5576c;border-radius:10px;padding:30px 20px;text-align:center;background:#fff5f7;transition:all .3s;cursor:pointer}.imagen-input-wrapper:hover{background:#ffe8ed;border-color:#f093fb;transform:translateY(-2px)}.imagen-input-wrapper.dragover{background:#f5f5f5;border-color:#667eea;box-shadow:0 0 10px #667eea4d}.imagen-input-wrapper input[type=file]{display:none}.imagen-input-label{display:flex;flex-direction:column;align-items:center;gap:12px;cursor:pointer;-webkit-user-select:none;user-select:none}.imagen-input-icon{font-size:3rem;line-height:1}.imagen-input-text{font-weight:600;color:#f5576c;margin:0}.imagen-input-subtext{font-size:.9rem;color:#999;margin:0}.imagen-input-hint{font-size:.8rem;color:#aaa;margin-top:8px}.footer-editor{text-align:center;margin:10px;color:#fff}.footer-editor a{color:#fff;text-decoration:none;font-weight:600;display:inline-block;background:#fff3;padding:8px 15px;border-radius:20px;transition:all .3s}.gif-search-wrapper{margin-bottom:15px}.gif-search-form{display:flex;gap:10px}.gif-search-input{flex:1;padding:12px 15px;border:2px solid #f0f0f0;border-radius:10px;font-size:1rem;transition:all .3s}.gif-search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.gif-search-btn{padding:10px;background:linear-gradient(135deg,#667eea,#5568d3);color:#fff;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .3s;white-space:nowrap}.gif-search-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #667eea4d}.gif-search-btn:disabled{opacity:.6;cursor:not-allowed}.gifs-results{margin-top:20px;padding:15px;background:#f9f9f9;border-radius:10px}.gifs-results h4{color:#333;margin-bottom:15px;font-size:1rem}.gifs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:10px;margin-bottom:15px}.gif-item{cursor:pointer;border-radius:8px;overflow:hidden;aspect-ratio:1;transition:all .3s;border:2px solid transparent}.gif-item img{width:100%;height:100%;object-fit:cover}.gif-item:hover{border-color:#f5576c;transform:scale(1.05);box-shadow:0 4px 12px #f5576c33}.btn-cerrar-gifs{width:100%;background:#e0e0e0;color:#333;padding:10px;border-radius:8px;font-size:.95rem;cursor:pointer;transition:all .3s}.btn-cerrar-gifs:hover{background:#d0d0d0}.imagen-source{text-align:center;color:#667eea;font-size:.85rem;margin-top:10px;font-weight:600}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;z-index:1000;display:flex;justify-content:center;align-items:center;animation:fadeIn .3s ease}.modal-content{background:#fff;border-radius:15px;box-shadow:0 20px 60px #0000004d;max-width:450px;width:90%;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:15px;border-bottom:2px solid #f0f0f0;color:#000}.modal-header h3{font-size:1.3rem;margin:0;font-weight:600}.btn-close-modal{background:transparent;border:none;color:#000;font-size:1rem;cursor:pointer;padding:0;max-width:40px;height:40px;display:flex;align-items:center;justify-content:center;transition:all .3s}.btn-close-modal:hover{transform:scale(1.1);opacity:.8}.modal-body{padding:30px}.form-group-modal{margin:20px 0}.form-group-modal label{display:block;margin-bottom:8px;color:#333;font-weight:600;font-size:1rem}.form-group-modal input{width:100%;padding:12px 15px;border:2px solid #f0f0f0;border-radius:10px;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:1rem;transition:all .3s;resize:none}.form-group-modal input:focus{outline:none;border-color:#f5576c;box-shadow:0 0 0 3px #f5576c1a}.form-group-modal input::placeholder{color:#ccc}.modal-buttons{display:flex;gap:10px;margin-top:25px}.btn-modal-submit,.btn-modal-cancel{flex:1;padding:12px 20px;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.btn-modal-submit{background:#1e1e1e;color:#fff}.btn-modal-submit:active{transform:translateY(0)}.btn-modal-cancel{background:#f0f0f0;color:#333}.btn-modal-cancel:hover{background:#e0e0e0}@media (max-width: 768px){.container-editor{padding:0}.editor-card{padding:20px;border-radius:12px}.form-group{margin-bottom:18px}label{font-size:1rem;margin-bottom:6px}textarea{min-height:110px;font-size:16px;padding:10px 12px}input[type=text]{height:40px;font-size:16px;padding:10px 12px}input[type=file]{font-size:.95rem}.btn-editor{padding:12px;font-size:.95rem}.button-group{flex-direction:column;gap:10px}.btn-ver{margin-top:0}.char-counter{font-size:.8rem}.saludos-guardados{max-height:200px;padding:12px;margin-top:15px}.saludos-guardados h3{font-size:.95rem}.saludo-item{padding:8px;margin-bottom:8px;font-size:.85rem}.imagen-input-wrapper{padding:20px 12px}.imagen-input-icon{font-size:2.5rem}.imagen-input-text{font-size:.9rem}.imagen-input-subtext{font-size:.75rem}.footer-editor{margin-top:20px;font-size:.85rem}.footer-editor a{padding:6px 12px;font-size:.85rem}}@media (max-width: 480px){.container-editor{padding:0 15px}.editor-card{padding:16px;border-radius:10px}.form-group{margin-bottom:16px}label{font-size:.95rem;margin-bottom:5px}textarea{min-height:100px;font-size:16px;padding:8px 10px;border-radius:8px}input[type=text]{height:38px;font-size:16px;padding:8px 10px;border-radius:8px}input[type=file]{padding:8px 10px;font-size:.9rem}.btn-editor{padding:10px;font-size:.9rem;border-radius:8px}.button-group{flex-direction:column;gap:8px}.char-counter{font-size:.75rem}.imagen-preview img{max-height:250px;max-width:100%}.btn-limpiar-imagen{font-size:.8rem;padding:6px 8px}.saludo-item{padding:7px;margin-bottom:6px;font-size:.8rem}.saludo-item-texto{margin-bottom:2px}.saludo-item-hora{margin-top:3px}.scroll-indicator{font-size:.75rem;padding-top:6px}.saludos-guardados{max-height:180px;padding:10px;margin-top:12px}.saludos-guardados h3{font-size:.9rem}.imagen-input-wrapper{padding:15px 10px;border-radius:8px}.imagen-input-icon{font-size:2.2rem;line-height:1}.imagen-input-text{font-size:.85rem}.imagen-input-subtext{font-size:.7rem}.imagen-input-hint{font-size:.75rem}.footer-editor{margin-top:15px;font-size:.8rem}.footer-editor a{padding:5px 10px;font-size:.8rem}.modal-content{width:95%;border-radius:12px}.modal-header{padding:15px;border-radius:12px 12px 0 0}.modal-header h3{font-size:1.1rem}.modal-body{padding:20px}.form-group-modal label{font-size:.95rem}.form-group-modal input{padding:10px 12px;font-size:16px}.modal-buttons{gap:8px;margin-top:20px}.btn-modal-submit,.btn-modal-cancel{padding:10px 15px;font-size:.95rem}}.cancion-search-form{display:flex;gap:10px;margin-bottom:12px}.cancion-search-form input{flex:1;padding:10px 14px;border:2px solid #f0f0f0;border-radius:10px;font-size:1rem;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;transition:border-color .3s}.cancion-search-form input:focus{outline:none;border-color:#1db954}.cancion-search-form .btn-modal-submit{flex-shrink:0;padding:10px 16px;font-size:.9rem;white-space:nowrap}.cancion-results{max-height:320px;overflow-y:auto;border:2px solid #f0f0f0;border-radius:10px;margin-bottom:10px}.cancion-result-item{display:flex;align-items:center;gap:12px;padding:10px 12px;cursor:pointer;border-bottom:1px solid #f5f5f5;transition:background .2s}.cancion-result-item:last-child{border-bottom:none}.cancion-result-item:hover{background:#f9f9f9}.cancion-result-item.selected{background:#f0fff4;border:3px solid #1DB954}.cancion-portada{width:48px;height:48px;border-radius:6px;object-fit:cover;flex-shrink:0}.cancion-info{flex:1;min-width:0}.cancion-nombre{font-weight:600;font-size:.95rem;color:#1a1a1a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cancion-artista{font-size:.82rem;color:#777;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cancion-check{font-size:1.2rem;color:#1db954;font-weight:700;flex-shrink:0}.admin-login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.admin-login-card{background:#fff;border-radius:16px;padding:40px;width:100%;max-width:400px;box-shadow:0 20px 60px #0000004d}.admin-login-title{color:#333;margin:0 0 30px;text-align:center;font-size:28px;font-weight:700}.admin-login-form{display:flex;flex-direction:column;gap:20px}.admin-login-group{display:flex;flex-direction:column;gap:8px}.admin-login-label{color:#555;font-weight:600;font-size:14px;text-transform:uppercase;letter-spacing:.5px}.admin-login-input{padding:12px 14px;border:2px solid #e0e0e0;border-radius:8px;font-size:15px;font-family:inherit;transition:all .3s ease;background:#f9f9f9}.admin-login-input:focus{outline:none;border-color:#667eea;background:#fff;box-shadow:0 0 0 3px #667eea1a}.admin-login-input:disabled{opacity:.6;cursor:not-allowed;background:#f0f0f0}.admin-login-btn{padding:12px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:700;cursor:pointer;transition:all .3s ease;margin-top:10px}.admin-login-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.admin-login-btn:active:not(:disabled){transform:translateY(0)}.admin-login-btn:disabled{opacity:.6;cursor:not-allowed}.admin-login-footer{text-align:center;margin-top:20px;padding-top:20px;border-top:1px solid #e0e0e0}.admin-login-back{color:#667eea;text-decoration:none;font-weight:600;transition:color .3s ease}.admin-login-back:hover{color:#764ba2}.admin-loading{display:flex;justify-content:center;align-items:center;min-height:100vh;font-size:20px;color:#667eea;background:linear-gradient(135deg,#667eea,#764ba2)}.admin-dashboard{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:40px 20px;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.admin-header{max-width:1200px;margin:0 auto 40px;display:flex;justify-content:space-between;align-items:center;color:#fff}.admin-header h1{margin:0;font-size:32px;font-weight:700}.admin-logout-btn{padding:10px 20px;background:#fff3;color:#fff;border:2px solid white;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.admin-logout-btn:hover{background:#ffffff4d;transform:translateY(-2px)}.admin-content{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:30px}.admin-card{background:#fff;border-radius:12px;padding:25px;box-shadow:0 10px 30px #0003;transition:transform .3s ease,box-shadow .3s ease}.admin-card:hover{transform:translateY(-5px);box-shadow:0 15px 40px #00000040}.admin-card h2{color:#333;margin:0 0 15px;font-size:20px;font-weight:700}.admin-card p{color:#666;margin:10px 0;line-height:1.6}.admin-card strong{color:#667eea}.admin-features{list-style:none;padding:0;margin:0}.admin-features li{color:#555;padding:10px 0;font-size:15px;border-bottom:1px solid #f0f0f0}.admin-features li:last-child{border-bottom:none}@media (max-width: 768px){.admin-login-card{padding:30px 20px}.admin-login-title{font-size:24px}.admin-header{flex-direction:column;gap:15px;text-align:center}.admin-header h1{font-size:24px}.admin-logout-btn{width:100%}.admin-content{grid-template-columns:1fr}}.admin-saludos-section{max-width:1200px;margin:0 auto 40px;background:#fff;border-radius:12px;padding:25px;box-shadow:0 10px 30px #0003}.admin-saludos-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.admin-saludos-header h2{margin:0;font-size:20px;font-weight:700;color:#333;display:flex;align-items:center;gap:8px}.admin-refresh-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .3s ease}.admin-refresh-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px #667eea59}.admin-refresh-btn:disabled{opacity:.6;cursor:not-allowed}.admin-saludos-estado{text-align:center;color:#888;padding:40px 0;font-size:15px}.admin-saludos-table-wrapper{overflow-x:auto;border-radius:8px;border:1px solid #eee}.admin-saludos-table{width:100%;border-collapse:collapse;font-size:14px}.admin-saludos-table thead tr{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.admin-saludos-table th{padding:12px 14px;text-align:left;font-weight:600;font-size:13px;letter-spacing:.3px;white-space:nowrap}.admin-saludos-table td{padding:10px 14px;border-bottom:1px solid #f0f0f0;vertical-align:middle;color:#444}.admin-saludos-table tbody tr:last-child td{border-bottom:none}.admin-saludos-table tbody tr:hover{background:#fafafa}.admin-row-deleting{opacity:.4;pointer-events:none}.admin-col-fecha{white-space:nowrap;font-size:12px;color:#888!important}.admin-col-de{font-weight:600;color:#333!important;white-space:nowrap}.admin-col-saludo{max-width:320px}.admin-col-ip code{background:#f0f0f0;padding:2px 7px;border-radius:4px;font-size:12px;color:#555;white-space:nowrap}.admin-col-actions{white-space:nowrap;display:flex;gap:6px}.admin-btn-action{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:6px;cursor:pointer;font-size:13px;transition:all .2s ease}.admin-btn-action:disabled{opacity:.4;cursor:not-allowed}.admin-btn-delete{background:#fee2e2;color:#dc2626}.admin-btn-delete:hover:not(:disabled){background:#dc2626;color:#fff}.admin-btn-block{background:#fef3c7;color:#d97706}.admin-btn-block:hover:not(:disabled){background:#d97706;color:#fff}@keyframes fa-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.fa-spin{animation:fa-spin 1s linear infinite}@media (max-width: 768px){.admin-saludos-header{flex-direction:column;align-items:flex-start;gap:12px}.admin-col-saludo{max-width:180px}}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;padding:0}#root{width:100%;margin:0;padding:0}.app-header{position:sticky;top:0;display:flex;justify-content:center;align-items:center;width:100%;height:70px;padding:0 20px;margin-bottom:10px;z-index:10}.app-header-left,.app-header-right{position:absolute;flex:0 0 auto;display:flex;align-items:center;justify-content:center;gap:10px;height:100%}.app-header-left{left:5px}.app-header-right{right:5px}.app-header-content{flex:1;text-align:center;display:flex;flex-direction:column;justify-content:center;align-items:center}.app-header-title{margin:0;font-weight:700;line-height:1.2}.app-header-subtitle{margin:0;font-size:.95rem;opacity:.85;line-height:1.3}.app-header-display{background:transparent;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.app-header-display .app-header-title{font-size:1.5rem;color:#f1f1f1}.app-header-display .app-header-subtitle{font-size:1.2rem;color:#f1f1f1e6}.app-header-editor{background:transparent}.app-header-editor .app-header-content{padding:0 15px}.app-header-editor .app-header-title{font-size:1.2rem;color:#fff;font-weight:700}.app-header-editor .app-header-subtitle{font-size:.9rem;color:#fffc}.sidebar-toggle-btn{background:#fff;border:none;padding:0;border-radius:8px;cursor:pointer;font-size:1.1rem;transition:all .3s ease;display:flex;align-items:center;justify-content:center;color:#667eea;font-weight:600;text-decoration:none;width:40px;height:40px}.sidebar-toggle-back{background:#fff;border:none;padding:8px 14px;border-radius:8px;cursor:pointer;font-size:1rem;transition:all .3s ease;display:flex;align-items:center;justify-content:center;color:#667eea;font-weight:600;text-decoration:none;height:40px;gap:6px}.sidebar-toggle-btn:hover,.sidebar-toggle-back:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}@media (min-width: 769px){.app-header-display .app-header-left{display:none}}@media (max-width: 768px){.app-header{padding:15px 0;margin-bottom:20px}.app-header-display .app-header-title{font-size:2rem}.app-header-display .app-header-subtitle{font-size:.9rem}.app-header-editor .app-header-title{font-size:1rem}.app-header-editor .app-header-subtitle{font-size:.8rem}}@media (max-width: 480px){.app-header{padding:12px 0;margin-bottom:15px}.app-header-display .app-header-title{font-size:1.5rem}.app-header-display .app-header-subtitle{font-size:.8rem}.app-header-editor .app-header-title{font-size:1.1rem}.app-header-editor .app-header-subtitle{font-size:.75rem}}
