*{margin:0;padding:0;box-sizing:border-box}:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid 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}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e3f2fd,#f8f9fa);padding:20px}.auth-card{background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;padding:40px;width:100%;max-width:450px;animation:slideUp .5s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.auth-header{text-align:center;margin-bottom:30px}.auth-header h1{font-size:2.5rem;font-weight:700;color:#529fd9;margin-bottom:10px}.auth-header h2{font-size:1.8rem;color:#333;margin-bottom:8px;font-weight:600}.auth-header p{color:#666;font-size:.95rem}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:500;color:#333;font-size:.9rem}.form-group input{padding:12px 16px;border:2px solid #e0e0e0;border-radius:10px;font-size:1rem;transition:all .3s ease;font-family:inherit}.form-group input:focus{outline:none;border-color:#529fd9;box-shadow:0 0 0 3px #529fd91a}.form-group input::placeholder{color:#999}.auth-button{background:#529fd9;color:#fff;border:none;padding:14px 24px;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:10px;box-shadow:0 4px 15px #529fd966}.auth-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #529fd980;background:#4a8fc4}.auth-button:active{transform:translateY(0)}.error-message{background-color:#fee;color:#c33;padding:12px 16px;border-radius:8px;border-left:4px solid #c33;font-size:.9rem;margin-bottom:10px}.success-message{background-color:#efe;color:#3c3;padding:12px 16px;border-radius:8px;border-left:4px solid #3c3;font-size:.9rem;margin-bottom:10px}.auth-footer{text-align:center;margin-top:25px;padding-top:25px;border-top:1px solid #e0e0e0}.auth-footer p{color:#666;font-size:.9rem}.auth-link{color:#529fd9;text-decoration:none;font-weight:600;transition:color .3s ease}.auth-link:hover{color:#4a8fc4;text-decoration:underline}@media(max-width:480px){.auth-card{padding:30px 20px}.auth-header h1{font-size:2rem}.auth-header h2{font-size:1.5rem}}.dashboard-container{min-height:100vh;background:linear-gradient(135deg,#e3f2fd,#f8f9fa);padding:20px}.dashboard-header{display:flex;justify-content:space-between;align-items:center;background:#fff;padding:20px 40px;border-radius:15px;box-shadow:0 4px 15px #0000001a;margin-bottom:30px}.dashboard-header h1{font-size:2rem;font-weight:700;color:#529fd9;margin:0}.logout-button{background:#f44336;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease}.logout-button:hover{background:#d32f2f;transform:translateY(-2px);box-shadow:0 4px 10px #f443364d}.dashboard-content{background:#fff;padding:40px;border-radius:15px;box-shadow:0 4px 15px #0000001a;max-width:1400px;margin:0 auto}.welcome-section{margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center;gap:20px}.welcome-section h2{color:#333;font-size:1.8rem;margin:0;flex:1;min-width:0;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;line-height:1.4;max-height:2.8em}.manage-users-button{background:#529fd9;color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:600;transition:background .3s}.manage-users-button:hover{background:#4289c7}.no-role-message{display:flex;justify-content:center;align-items:center;min-height:400px;padding:20px}.no-role-card{background:#fff;padding:40px;border-radius:15px;box-shadow:0 4px 15px #0000001a;max-width:600px;text-align:center}.no-role-card h3{color:#529fd9;font-size:1.8rem;margin-bottom:20px}.no-role-card p{color:#666;font-size:1rem;line-height:1.6;margin:15px 0}.no-role-hint{color:#999;font-size:.9rem;font-style:italic;margin-top:20px}.users-management{background:#fff;padding:25px;border-radius:10px;margin-bottom:20px;box-shadow:0 2px 8px #0000001a}.users-management h3{color:#333;margin-bottom:20px;font-size:1.5rem}.users-search-container{margin-bottom:20px}.users-search-input{width:100%;padding:12px 15px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .3s}.users-search-input:focus{outline:none;border-color:#529fd9}.users-search-input::placeholder{color:#999}.anuncios-search-container{margin-bottom:20px}.anuncios-search-input{width:100%;padding:12px 15px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .3s}.anuncios-search-input:focus{outline:none;border-color:#529fd9}.anuncios-search-input::placeholder{color:#999}.users-table{overflow-x:auto}.users-table table{width:100%;border-collapse:collapse}.users-table th,.users-table td{padding:12px;text-align:left;border-bottom:1px solid #e0e0e0}.users-table th{background:#f8f9fa;font-weight:600;color:#333}.users-table tr:hover{background:#f8f9fa}.role-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:.85rem;font-weight:600;background:#529fd9;color:#fff}.role-badge.no-role{background:#ff9800}.role-select{padding:6px 10px;border:1px solid #ddd;border-radius:6px;font-size:.9rem;min-width:150px}.role-actions{display:flex;gap:8px}.edit-role-button,.save-role-button,.cancel-role-button{padding:6px 12px;border:none;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:600;transition:background .3s}.edit-role-button{background:#529fd9;color:#fff}.edit-role-button:hover{background:#4289c7}.save-role-button{background:#28a745;color:#fff}.save-role-button:hover{background:#218838}.cancel-role-button{background:#6c757d;color:#fff}.cancel-role-button:hover{background:#5a6268}.tabs-container{width:100%}.tabs{display:flex;gap:10px;margin-bottom:30px;border-bottom:2px solid #e0e0e0;flex-wrap:wrap;align-items:center}.tab-wrapper{display:flex;align-items:center;gap:5px;position:relative}.tab-button{background:transparent;border:none;padding:15px 25px;font-size:1rem;font-weight:600;color:#666;cursor:pointer;transition:all .3s ease;position:relative;border-bottom:3px solid transparent;margin-bottom:-2px}.tab-delete-button{background:#f44336;color:#fff;border:none;width:20px;height:20px;border-radius:50%;font-size:14px;line-height:1;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;padding:0;margin-bottom:-2px;opacity:.7}.tab-delete-button:hover{opacity:1;background:#d32f2f;transform:scale(1.1)}.add-tab-button{background:#529fd9;color:#fff;border:none;width:40px;height:40px;border-radius:50%;font-size:1.5rem;font-weight:300;line-height:1;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;margin-bottom:-2px;box-shadow:0 2px 8px #529fd94d}.add-tab-button:hover{background:#4a8fc4;transform:scale(1.1);box-shadow:0 4px 12px #529fd966}.add-tab-form{background:#f8f9fa;padding:20px;border-radius:10px;margin-bottom:20px;border:2px solid #529fd9;display:flex;flex-direction:column;gap:15px;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.add-tab-form input{padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .3s ease}.add-tab-form input:focus{outline:none;border-color:#529fd9}.add-tab-actions{display:flex;gap:10px}.add-tab-submit{background:#529fd9;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease;flex:1}.add-tab-submit:hover{background:#4a8fc4;transform:translateY(-2px)}.add-tab-cancel{background:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease;flex:1}.add-tab-cancel:hover{background:#5a6268;transform:translateY(-2px)}.tab-button:hover{color:#529fd9;background:#529fd90d}.tab-button.active{color:#529fd9;border-bottom-color:#529fd9}.tab-button.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:3px;background:#529fd9}.tab-panel{min-height:400px;animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.tab-header-actions{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;padding-bottom:20px;border-bottom:2px solid #e0e0e0}.tab-header-actions h2{color:#333;font-size:2rem;margin:0}.upload-button{background:#529fd9;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #529fd94d}.upload-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #529fd966;background:#4a8fc4}.upload-form{background:#f8f9fa;padding:25px;border-radius:10px;margin-bottom:30px;border:2px dashed #529fd9}.upload-form .form-group{margin-bottom:20px}.upload-form label{display:block;font-weight:600;color:#333;margin-bottom:8px;font-size:.95rem}.upload-form input[type=text]{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .3s ease}.upload-form input[type=text]:focus{outline:none;border-color:#529fd9}.upload-form input[type=file]{width:100%;padding:10px;border:2px solid #e0e0e0;border-radius:8px;background:#fff;cursor:pointer}.file-info{margin-top:10px;color:#666;font-size:.9rem}.radio-group{display:flex;gap:20px;margin-top:10px}.radio-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:500;color:#333}.radio-label input[type=radio]{width:18px;height:18px;cursor:pointer;accent-color:#529fd9}.submit-button{background:#28a745;color:#fff;border:none;padding:12px 30px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;width:100%}.submit-button:hover{background:#218838;transform:translateY(-2px)}.anuncios-section{margin-top:30px}.filter-tabs-container{margin-bottom:25px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:15px}.show-hidden-toggle{display:flex;align-items:center}.toggle-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.9rem;color:#666;-webkit-user-select:none;user-select:none}.toggle-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#529fd9}.filter-tabs{display:flex;gap:10px;border-bottom:2px solid #e0e0e0;flex-wrap:wrap}.filter-tab{background:transparent;border:none;padding:12px 20px;font-size:.95rem;font-weight:600;color:#666;cursor:pointer;transition:all .3s ease;position:relative;border-bottom:3px solid transparent;margin-bottom:-2px}.filter-tab:hover{color:#529fd9;background:#529fd90d}.filter-tab.active{color:#529fd9;border-bottom-color:#529fd9}.filter-tab.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:3px;background:#529fd9}.anuncios-container{display:flex;flex-direction:column;gap:30px}.anuncios-grandes-section{display:flex;flex-direction:column;gap:25px}.anuncios-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:25px}.anuncio-card{background:#fff;border:2px solid #e0e0e0;border-radius:12px;overflow:hidden;transition:all .3s ease;box-shadow:0 2px 8px #0000001a}.anuncio-card:hover{transform:translateY(-5px);box-shadow:0 6px 20px #00000026;border-color:#529fd9}.anuncio-card.anuncio-grande{width:100%;max-width:100%}.anuncio-content-grande{height:500px!important}.anuncio-header{display:flex;justify-content:space-between;align-items:center;padding:15px;background:#f8f9fa;border-bottom:1px solid #e0e0e0}.anuncio-header h3{margin:0;color:#333;font-size:1.1rem;font-weight:600;flex:1}.anuncio-actions{display:flex;gap:8px;align-items:center}.visibility-button{background:#ff9800;color:#fff;border:none;width:30px;height:30px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;padding:0;overflow:hidden}.visibility-button:hover{background:#f57c00;transform:scale(1.1)}.visibility-icon{width:20px;height:20px;object-fit:contain}.delete-button{background:#f44336;color:#fff;border:none;width:30px;height:30px;border-radius:50%;font-size:1.5rem;line-height:1;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.delete-button:hover{background:#d32f2f;transform:scale(1.1)}.anuncio-oculto{opacity:.6;border:2px dashed #999}.anuncio-oculto .anuncio-header{background:#e0e0e0}.anuncio-content{width:100%;height:250px;overflow:hidden;background:#000;display:flex;align-items:center;justify-content:center}.anuncio-media{width:100%;height:100%;object-fit:contain}.anuncio-footer{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;background:#f8f9fa;border-top:1px solid #e0e0e0;gap:10px;flex-wrap:wrap}.anuncio-tamaño{background:#28a745;color:#fff;padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:600}.anuncio-segundos{background:#ff9800;color:#fff;padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:600}.anuncio-tipo{background:#529fd9;color:#fff;padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:600}.anuncio-fecha{color:#666;font-size:.85rem}.anuncio-author{display:flex;align-items:center;gap:8px;padding:10px 15px;background:#f0f0f0;border-top:1px solid #e0e0e0;font-size:.85rem}.author-label{color:#666;font-weight:500}.author-name{color:#529fd9;font-weight:600}.empty-state{text-align:center;padding:60px 20px;color:#999}.empty-state p{font-size:1.1rem;margin:10px 0}.empty-hint{font-size:.9rem!important;color:#bbb!important}@media(max-width:768px){.welcome-section{flex-direction:column;align-items:stretch;gap:15px;padding:15px}.welcome-section h2{width:100%;font-size:1.5rem;max-width:100%;flex:none}.manage-users-button{width:100%;text-align:center;align-self:stretch}.dashboard-header{flex-direction:column;gap:15px;padding:20px}.dashboard-content{padding:30px 20px}.tabs{flex-direction:column;gap:5px}.tab-button{width:100%;text-align:left;padding:12px 20px}.tab-header-actions{flex-direction:column;align-items:flex-start;gap:15px}.tab-header-actions h2{font-size:1.5rem}.upload-button{width:100%}.anuncios-grid{grid-template-columns:1fr}.anuncio-content-grande{height:300px!important}.radio-group{flex-direction:column;gap:10px}.filter-tabs{flex-direction:column;gap:5px}.filter-tab{width:100%;text-align:left;padding:10px 15px}.tab-wrapper{flex:1;min-width:0}.tab-button{width:100%;padding:12px 15px}.add-tab-button{width:100%;height:auto;padding:12px;border-radius:8px;margin-top:10px}.add-tab-form{margin-top:10px}}
