/* Responsividad y detalles visuales unificados */
@media (max-width: 900px) {
	.rifa-campania { max-width: 99vw; padding: 0 0.5rem 2rem 0.5rem; }
	.rifa-hero { padding: 1.2rem 0.2rem 1.5rem 0.2rem; }
	.rifa-hero-img { width: 90vw; max-width: 98vw; height: 32vw; min-height: 110px; }
}
@media (max-width: 700px) {
	.rifa-cards-resumen { flex-direction: column; gap: 1.1rem; }
	.rifa-card-resumen { min-width: 0; width: 100%; }
	.rifa-barra-progreso-wrap { max-width: 99vw; }
	.rifa-transparencia-block { max-width: 99vw; }
}
@media (max-width: 600px) {
	.rifa-campania { padding: 0 0.1rem 1.2rem 0.1rem; }
	.rifa-hero-img { width: 98vw; max-width: 98vw; height: 34vw; min-height: 90px; }
	.rifa-titulo { font-size: 1.1rem; }
	.rifa-subtitulo { font-size: 0.98rem; }
	.rifa-barra-progreso-label { font-size: 1rem; }
	.rifa-card-value { font-size: 1.3rem; }
	.rifa-card-label { font-size: 0.98rem; }
	.rifa-num-btn { font-size: 0.98rem; padding: 10px 0; }
	.rifa-bloques-grid { gap: 7px; }
	.rifa-numeros-grid { gap: 7px; }
	.rifa-fab { width: 96vw; min-width: 0; font-size: 1.01rem; padding: 0.9em 0.5em; border-radius: 22px; }
	.rifa-fab-text { font-size: 1em; }
}
@media (max-width: 400px) {
	.rifa-titulo { font-size: 0.98rem; }
	.rifa-subtitulo { font-size: 0.85rem; }
	.rifa-card-value { font-size: 1.1rem; }
	.rifa-barra-progreso-label { font-size: 0.92rem; }
}
/* Botón flotante de acción (FAB) */
.rifa-fab {
	position: fixed;
	left: 50%;
	bottom: 24px;
	transform: translateX(-50%);
	z-index: 9999;
	background: linear-gradient(90deg, #24e0a5 0%, #0f7aff 100%);
	color: #fff;
	font-size: 1.18rem;
	font-weight: 700;
	border: none;
	border-radius: 32px;
	box-shadow: 0 8px 32px rgba(36,224,165,0.18), 0 2px 8px rgba(15,122,255,0.10);
	padding: 0.95em 2.2em 0.95em 1.5em;
	display: flex;
	align-items: center;
	gap: 0.7em;
	cursor: pointer;
	transition: background .18s, box-shadow .18s, transform .18s;
	outline: none;
	animation: rifa-fab-in 0.7s cubic-bezier(.77,0,.18,1);
}
.rifa-fab:hover, .rifa-fab:focus {
	background: linear-gradient(90deg, #0f7aff 0%, #24e0a5 100%);
	box-shadow: 0 12px 36px rgba(36,224,165,0.22), 0 4px 12px rgba(15,122,255,0.13);
	transform: translateX(-50%) scale(1.04);
}
.rifa-fab-icon {
	font-size: 1.5em;
	filter: drop-shadow(0 2px 6px rgba(36,224,165,0.10));
}
@keyframes rifa-fab-in {
	0% { opacity: 0; transform: translateX(-50%) translateY(40px) scale(0.8); }
	100% { opacity: 1; transform: translateX(-50%) translateY(0) scale(1); }
}
@media (max-width: 600px) {
	.rifa-fab { width: 96vw; min-width: 0; font-size: 1.01rem; padding: 0.9em 0.5em; border-radius: 22px; }
	.rifa-fab-text { font-size: 1em; }
}
/* Bloque de transparencia emocional */
.rifa-transparencia-block {
	background: linear-gradient(90deg, #eaffea 60%, #f6f9ff 100%);
	border-radius: 16px;
	box-shadow: 0 2px 10px rgba(36,224,165,0.07);
	padding: 1.1rem 1.2rem;
	margin: 0 auto 1.7rem auto;
	max-width: 540px;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.7rem;
	font-size: 1.13rem;
	color: #1b2433;
	font-weight: 600;
	text-align: center;
}
.rifa-transparencia-icon {
	font-size: 1.5rem;
	color: #24e0a5;
	filter: drop-shadow(0 2px 6px rgba(36,224,165,0.10));
}
.rifa-transparencia-text {
	flex: 1;
}
@media (max-width: 600px) {
	.rifa-transparencia-block { font-size: 1rem; padding: 0.8rem 0.5rem; }
	.rifa-transparencia-icon { font-size: 1.2rem; }
}
/* Separador visual antes de los números */
.rifa-separador-numeros {
	text-align: center;
	margin: 2.2rem 0 1.2rem 0;
}
.rifa-separador-numeros h3 {
	font-size: 1.45rem;
	font-weight: 700;
	color: #0f7aff;
	margin-bottom: 0.4rem;
	letter-spacing: -0.01em;
}
.rifa-separador-linea {
	width: 80px;
	height: 4px;
	margin: 0 auto;
	border-radius: 3px;
	background: linear-gradient(90deg, #24e0a5 0%, #0f7aff 100%);
	box-shadow: 0 2px 8px rgba(36,224,165,0.10);
}
/* Barra de progreso grande y animada */
.rifa-barra-progreso-wrap {
	margin: 1.5rem auto 1.7rem auto;
	max-width: 520px;
	width: 100%;
	text-align: center;
}
.rifa-barra-progreso-label {
	font-size: 1.13rem;
	font-weight: 700;
	color: #24e0a5;
	margin-bottom: 0.4rem;
	letter-spacing: 0.01em;
}
.rifa-barra-progreso {
	width: 100%;
	height: 22px;
	background: #eaffea;
	border-radius: 16px;
	overflow: hidden;
	box-shadow: 0 2px 10px rgba(36,224,165,0.08);
	position: relative;
}
.rifa-barra-fill {
	height: 100%;
	background: linear-gradient(90deg, #24e0a5 0%, #0f7aff 100%);
	border-radius: 16px 0 0 16px;
	transition: width 1.1s cubic-bezier(.77,0,.18,1);
	width: 0%;
	min-width: 2.5%;
	box-shadow: 0 2px 10px rgba(36,224,165,0.13);
}
/* Tarjetas visuales de resumen */
.rifa-cards-resumen {
	display: flex;
	gap: 1.5rem;
	justify-content: center;
	align-items: stretch;
	margin-bottom: 1.7rem;
	flex-wrap: wrap;
}
.rifa-card-resumen {
	background: #fff;
	border-radius: 18px;
	box-shadow: 0 4px 18px rgba(15,122,255,0.07), 0 1.5px 4px rgba(36,224,165,0.08);
	padding: 1.2rem 1.3rem 1.1rem 1.3rem;
	min-width: 150px;
	flex: 1 1 180px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	transition: box-shadow .2s;
	position: relative;
}
.rifa-card-resumen:hover {
	box-shadow: 0 8px 32px rgba(15,122,255,0.13), 0 2px 8px rgba(36,224,165,0.10);
}
.rifa-card-icon {
	font-size: 2.1rem;
	margin-bottom: 0.5rem;
	color: #24e0a5;
	filter: drop-shadow(0 2px 6px rgba(36,224,165,0.10));
}
.rifa-card-label {
	font-size: 1.02rem;
	color: #6b7280;
	margin-bottom: 0.2rem;
	font-weight: 500;
	letter-spacing: 0.01em;
}
.rifa-card-value {
	font-size: 2.1rem;
	font-weight: 800;
	color: #0f7aff;
	letter-spacing: -0.01em;
	margin-bottom: 0.1rem;
}
.rifa-total-recaudado {
	text-align: center;
	font-size: 1.1rem;
	color: #24e0a5;
	font-weight: 600;
	margin-bottom: 1.2rem;
}
@media (max-width: 700px) {
	.rifa-cards-resumen { flex-direction: column; gap: 1.1rem; }
	.rifa-card-resumen { min-width: 0; width: 100%; }
}
.rifa-campania {
	max-width: 900px;
	margin: 0 auto;
	padding: 0 1rem 2.5rem 1rem;
}
.rifa-hero {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	background: linear-gradient(120deg, #eaffea 60%, #f6f9ff 100%);
	border-radius: 28px;
	box-shadow: 0 8px 32px rgba(36,224,165,0.10), 0 2px 8px rgba(15,122,255,0.06);
	padding: 2.2rem 1.2rem 2.5rem 1.2rem;
	margin-bottom: 2.2rem;
	position: relative;
	overflow: hidden;
}
.rifa-hero-img {
	width: 220px;
	height: 160px;
	margin: 0 auto 1.2rem auto;
	border-radius: 22px;
	overflow: hidden;
	box-shadow: 0 6px 24px rgba(36,224,165,0.13), 0 1px 4px rgba(15,122,255,0.08);
	background: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
}
.rifa-hero-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 22px;
	display: block;
}
.rifa-hero-text {
	text-align: center;
}
.rifa-titulo {
	font-size: 2.2rem;
	font-weight: 800;
	color: #0f7aff;
	margin-bottom: 0.7rem;
	letter-spacing: -0.01em;
	line-height: 1.15;
}
.rifa-subtitulo {
	font-size: 1.25rem;
	font-weight: 500;
	color: #24e0a5;
	margin-bottom: 0;
	line-height: 1.3;
}
@media (max-width: 600px) {
	.rifa-hero-img { width: 98vw; max-width: 98vw; height: 34vw; min-height: 120px; }
	.rifa-titulo { font-size: 1.25rem; }
	.rifa-subtitulo { font-size: 1rem; }
	.rifa-hero { padding: 1.2rem 0.2rem 1.5rem 0.2rem; }
}
.rifa-bloques-grid { display: flex; flex-wrap: wrap; gap: 12px; margin: 18px 0; }
.rifa-bloque-btn { background: #fff; border: 2px solid #0f7aff; color: #0f7aff; border-radius: 12px; padding: 12px 24px; font-size: 1.1rem; font-weight: 600; cursor: pointer; transition: background .2s, color .2s; }
.rifa-bloque-btn:hover { background: #0f7aff; color: #fff; }

.rifa-numeros-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(54px, 1fr));
	gap: 12px;
	margin: 22px 0 18px 0;
	justify-items: center;
}
.rifa-num-btn {
	border-radius: 12px;
	padding: 13px 0;
	font-size: 1.08rem;
	font-weight: 700;
	border: 2.5px solid #eee;
	background: #f6f9ff;
	color: #1b2433;
	cursor: pointer;
	transition: background .22s, color .22s, border .22s, box-shadow .22s, transform .18s cubic-bezier(.77,0,.18,1);
	box-shadow: 0 2px 8px rgba(36,224,165,0.06);
	outline: none;
	position: relative;
	will-change: transform, box-shadow;
}
.rifa-num-btn.disponible {
	background: #eaffea;
	border-color: #24e0a5;
	color: #1b2433;
	box-shadow: 0 2px 12px rgba(36,224,165,0.10);
}
.rifa-num-btn.disponible:hover, .rifa-num-btn.disponible:focus {
	background: #d2ffe0;
	border-color: #0f7aff;
	color: #0f7aff;
	transform: translateY(-4px) scale(1.07);
	box-shadow: 0 8px 32px rgba(36,224,165,0.18), 0 2px 8px rgba(15,122,255,0.10);
	z-index: 2;
	animation: rifa-glow 0.7s linear;
}
@keyframes rifa-glow {
	0% { box-shadow: 0 2px 12px rgba(36,224,165,0.10); }
	60% { box-shadow: 0 0 24px 8px #24e0a5aa; }
	100% { box-shadow: 0 8px 32px rgba(36,224,165,0.18), 0 2px 8px rgba(15,122,255,0.10); }
}
.rifa-num-btn.selected {
	animation: rifa-bounce 0.38s cubic-bezier(.77,0,.18,1);
	background: linear-gradient(90deg, #24e0a5 0%, #0f7aff 100%);
	color: #fff;
	border-color: #0f7aff;
	box-shadow: 0 8px 32px rgba(36,224,165,0.18), 0 2px 8px rgba(15,122,255,0.10);
}
@keyframes rifa-bounce {
	0% { transform: scale(1); }
	40% { transform: scale(1.18); }
	60% { transform: scale(0.93); }
	100% { transform: scale(1); }
}
.rifa-num-btn.vendido {
	background: #f7f7f7;
	border-color: #ff4f64;
	color: #ff4f64;
	cursor: not-allowed;
	opacity: 0.7;
	text-decoration: line-through;
}
.rifa-num-btn.reservado {
	background: #fffbe6;
	border-color: #f8c200;
	color: #bfa600;
	cursor: not-allowed;
	opacity: 0.8;
}
.rifa-num-btn:disabled {
	opacity: 0.7;
	cursor: not-allowed;
}
